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

 更新时间:2024年07月02日 10:01:52   作者:我写代码菜如坤  
在C#中实现字符串的模糊匹配可以借助正则表达式或者一些模糊匹配算法来实现,文章通过代码示例讲解的非常详细,对大家的学习或工作有一定的帮助,需要的朋友可以参考下

在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#字符串模糊匹配内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • c# Invoke和BeginInvoke 区别分析

    c# Invoke和BeginInvoke 区别分析

    这篇文章主要介绍了c# Invoke和BeginInvoke 区别分析,需要的朋友可以参考下
    2014-10-10
  • C# 使用WPF 用MediaElement控件实现视频循环播放

    C# 使用WPF 用MediaElement控件实现视频循环播放

    在WPF里用MediaElement控件,实现一个循环播放单一视频的程序,同时可以控制视频的播放、暂停、停止。这篇文章给大家介绍了C# 使用WPF 用MediaElement控件实现视频循环播放,需要的朋友参考下吧
    2018-04-04
  • 深入了解c#多线程编程

    深入了解c#多线程编程

    这篇文章主要介绍了c#多线程编程的相关资料,文中讲解非常细致,帮助大家更好的理解和学习c# 多线程,感兴趣的朋友可以了解下
    2020-08-08
  • c# chart缩放,局部放大问题

    c# chart缩放,局部放大问题

    这篇文章主要介绍了c# chart缩放,局部放大问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-03-03
  • c#删除代码中的单行注释行示例

    c#删除代码中的单行注释行示例

    本文提供了c#删除代码中的单行注释行的示例,还可以看到文件流的使用方法,大家参考使用吧
    2014-01-01
  • C# 设计模式系列教程-模板方法模式

    C# 设计模式系列教程-模板方法模式

    模板方法模式通过把不变的行为搬移到超类,去除了子类中的重复代码,子类实现算法的某些细节,有助于算法的扩展。
    2016-06-06
  • C#迷你猜数实例分析

    C#迷你猜数实例分析

    这篇文章主要介绍了C#迷你猜数,实例分析C#操作数字及数组的相关技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-03-03
  • C#实现带引导窗体的窗体设计操作流程

    C#实现带引导窗体的窗体设计操作流程

    很多时候,我们的窗体设计需要一个引导窗体,当打开一个项目的窗体时,默认的是先打开一个欢迎或介绍项目信息的引导窗体,几秒钟后再打开项目的主窗体,本文给大家介绍了C#实现带引导窗体的窗体设计操作流程,感兴趣的朋友可以参考下
    2024-04-04
  • CefSharp如何进行页面的缩放(Ctrl+滚轮)

    CefSharp如何进行页面的缩放(Ctrl+滚轮)

    CefSharp简单来说就是一款.Net编写的浏览器包,本文主要介绍了CefSharp如何进行页面的缩放,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-06-06
  • DirectoryEntry配置IIS7出现ADSI Error:未知错误(0x80005000)

    DirectoryEntry配置IIS7出现ADSI Error:未知错误(0x80005000)

    这篇文章主要介绍了DirectoryEntry配置IIS7出现ADSI Error:未知错误(0x80005000)的解决办法
    2015-09-09

最新评论