当前位置: 代码网 > it编程>编程语言>C# > C#实现字符串模糊匹配的方法小结

C#实现字符串模糊匹配的方法小结

2024年09月08日 C# 我要评论
在c#中实现字符串的模糊匹配可以借助正则表达式或者一些模糊匹配算法来实现。方法一:使用正则表达式如果你的模糊匹配是基于简单的通配符(如*和?),可以通过正则表达式来实现。using system;us

在c#中实现字符串的模糊匹配可以借助正则表达式或者一些模糊匹配算法来实现。

方法一:使用正则表达式

如果你的模糊匹配是基于简单的通配符(如*?),可以通过正则表达式来实现。

using system;
using system.text.regularexpressions;
 
class program
{
    static void main()
    {
        string pattern = "he*o"; // 例如,模糊匹配模式
        string input = "hello"; // 要匹配的字符串
 
        // 将模糊匹配模式转换为正则表达式
        string regexpattern = "^" + regex.escape(pattern)
                                    .replace("\\*", ".*")
                                    .replace("\\?", ".") + "$";
 
        // 使用正则表达式进行匹配
        if (regex.ismatch(input, regexpattern))
        {
            console.writeline("字符串匹配成功!");
        }
        else
        {
            console.writeline("字符串匹配失败!");
        }
    }
}

方法二:使用模糊匹配算法

如果你需要更复杂的模糊匹配(例如模糊搜索、近似匹配等),可以使用字符串相似度算法,如levenshtein距离或者jaccard相似度等。这些算法可以衡量两个字符串之间的相似程度,然后根据阈值判断是否匹配。

以下是一个使用levenshtein距离算法进行模糊匹配的示例:

using system;
 
class program
{
    static void main()
    {
        string pattern = "hello"; // 模糊匹配模式
        string input = "hello"; // 要匹配的字符串
 
        int threshold = 2; // 可接受的最大编辑距离
 
        // 计算输入字符串与模式字符串的编辑距离
        int distance = computelevenshteindistance(input.tolower(), pattern.tolower());
 
        // 如果编辑距离在阈值范围内,则认为匹配成功
        if (distance <= threshold)
        {
            console.writeline("字符串匹配成功!");
        }
        else
        {
            console.writeline("字符串匹配失败!");
        }
    }
 
    // 计算levenshtein距离的方法
    static int computelevenshteindistance(string s, string t)
    {
        int n = s.length;
        int m = t.length;
        int[,] d = new int[n + 1, m + 1];
 
        // 初始化边界条件
        for (int i = 0; i <= n; i++)
        {
            d[i, 0] = i;
        }
        for (int j = 0; j <= m; j++)
        {
            d[0, j] = j;
        }
 
        // 计算编辑距离
        for (int j = 1; j <= m; j++)
        {
            for (int i = 1; i <= n; i++)
            {
                if (s[i - 1] == t[j - 1])
                {
                    d[i, j] = d[i - 1, j - 1];
                }
                else
                {
                    d[i, j] = math.min(d[i - 1, j] + 1, // 删除
                                      math.min(d[i, j - 1] + 1, // 插入
                                               d[i - 1, j - 1] + 1)); // 替换
                }
            }
        }
 
        return d[n, m];
    }
}

以上代码示例中,computelevenshteindistance方法计算了两个字符串之间的levenshtein距离,然后通过比较距离与设定的阈值来判断是否匹配。

根据你的具体需求,选择适合的方法来实现字符串的模糊匹配。

拓展:c#  list 中字段的模糊查找匹配实现

在游戏中,关于在列表中 查找某行数据时,需要通过关键字匹配,去遍历表中的数据,如果表中匹配到关键字,则返回该行数据,没有则返回null。比如查找在好友列表查找某个好友时。

建立一个 data 数据:用于保存item 的所有信息 (如: id,title,content,icon 等)

public class data{

  public int id;
  public string name;
  public string title;
  public string content;
  public string icon;
  ...
}

实现:

private list<data> onfindkeyword(string str, list<data> list){

list<data> m_list= new list<data>();
int count = list.count;
 for(int i=0; i<count; i++){
  data data = list[i];
  if(data.name.indexof(str) != -1)
  {
    m_list.add(data);
  }

 }
 return m_list; // 返回新的列表,符合模糊查询的结果列表
}

用foreach 遍历, 通过name模糊查找

private list<data> onfindkeyword(string str, list<data> list){

list<data> m_list= new list<data>();
foreach(data data in list)
{
  if(data.name.indexof(str) != -1){
    m_list.add(data);
  }

}
return m_list;

}

使用 list.find(); 通过name 精确查找,不存在返回null

private list<data> onfindkeyword(string str, list<data> list){

list<data> m_list= new list<data>();
data data = list.find(m_data=> m_data == str);
// 需要判断是否存在
if(data != null){
  m_list.add(data);
}
return m_list;
}

到此这篇关于c#实现字符串模糊匹配的方法小结的文章就介绍到这了,更多相关c#字符串模糊匹配内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com