加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

检查C#中字符串列表中是否存在字符串

发布时间:2020-12-15 23:35:48 所属栏目:百科 来源:网络整理
导读:您好我正在尝试找到最好和最有效的方法来预先形成字符串列表中的字符串. 我的情况是这样的: 从数据库中获取满足给定条件的所有字符串值. 创建具有6位数的随机代码,但它是字符串值. 检查生成的代码是否存在于字符串列表中.如果它确实再次生成代码,并执行它,
您好我正在尝试找到最好和最有效的方法来预先形成字符串列表中的字符串.

我的情况是这样的:

>从数据库中获取满足给定条件的所有字符串值.
>创建具有6位数的随机代码,但它是字符串值.
>检查生成的代码是否存在于字符串列表中.如果它确实再次生成代码,并执行它,直到找到字符串列表中不存在的唯一字符串.当你找到一个,返回它.

这是我的代码:

private static readonly string chars = "0123456789";

string IGenerateOtpCodeService.GenerateOtpCode()
{
    var otps = personalTestSessionRepository
        .FindAll(x => x.State == PersonalTestSessionStates.NotStarted)
        .Select(x => x.Person.Otp)
        .ToList()
        .Distinct();

    Random random = new Random();

    string otp = new string(Enumerable.Repeat(chars,6)
        .Select(s => s[random.Next(s.Length)]).ToArray());

    //preform check if otp exitst in otps list. if it does,generate otp again,else return otp
    return otp;
}

什么是最好的方法呢?它是while循环,一些LINQ表达,还是其他什么?

解决方法

您应该在ToList之前使用Distinct在数据库服务器上执行Distinct操作.然后你可以使用Any检查字符串是否存在.

var otps = personalTestSessionRepository
    .FindAll(x => x.State == PersonalTestSessionStates.NotStarted)
    .Select(x => x.Person.Otp)
    .Distinct();
    .ToList();

string otp = null;
var found = true; 
do
{
    otp = new string(Enumerable.Repeat(chars,6)
    .Select(s => s[random.Next(s.Length)]).ToArray());

    found = otps.Any(x=>x == otp);

} while(found)

return otp;

根据heinzbeinz建议,如果使用HashSet,代码将执行得更快.要使用HashSet,请使用以下代码

var otpsList = personalTestSessionRepository
    .FindAll(x => x.State == PersonalTestSessionStates.NotStarted)
    .Select(x => x.Person.Otp)
    .Distinct();
    .ToList();

var otps = new HashSet<string>(otpsList);

string otp = null;
var found = true; 
do
{
    otp = new string(Enumerable.Repeat(chars,6)
    .Select(s => s[random.Next(s.Length)]).ToArray());

    found = otps.Contains(otp);

} while(found)

return otp;

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读