应无所住,而生其心
排名
1
文章
860
粉丝
112
评论
163
net core webapi post传递参数
庸人 : 确实坑哈,我也是下班好了好几次,发现后台传递对象是可以的,但...
百度编辑器自定义模板
庸人 : 我建议换个编辑器,因为现在百度富文本已经停止维护了,用tinymec...
ICP备案 :渝ICP备18016597号-1
网站信息:2018-2025TNBLOG.NET
技术交流:群号656732739
联系我们:contact@tnblog.net
公网安备:50010702506256
欢迎加群交流技术

c#正则表达式操作字符串,常用匹配,正则表达式替换字符串。js正则表达式提取字符串

10315人阅读 2019/5/13 17:58 总访问:5182447 评论:0 收藏:0 手机
分类: .NET


先来个.*?的解释吧

.   :  单个任意字符

*  :  重复多次、贪婪匹配。注意*在正则中不是任意字符,而是一个限定限定出现的次数

?  :  出现1次或者0次、非贪婪匹配

 

匹配只能输入英文数字下划线,并且不能数字开头

代码如下:

  1. if (Regex.IsMatch(username, @"^[a-zA-Z_][A-Za-z0-9_]*$"))
  2. {
  3.     return Json("设置合法");
  4. }
  5. else
  6. {
  7.     return Json("设置不合法");
  8. }

提取一个字符串的中文


  1. string content = "SS上海xx北京";
  2. List<string> chs = new List<string>();
  3. Regex reg = new Regex("[\u4e00-\u9fa5]+");
  4. foreach (Match v in reg.Matches(content))
  5.     chs.Add(v.Value);

效果如下:


正则表达式拆分字符串


  1. string content = "SS上海xx上海";
  2. string[] sArray = Regex.Split(content, "上海", RegexOptions.IgnoreCase);

这个很简单,效果如下:

他可以根据一个字符串去拆分,后面的参数是忽略大小写



例子2:根据一个标签拆分字符串

拆分"aa<em>哈哈</em>bb<em>嘻嘻</em>cc"成 aa,bb,cc

  1.   string[] str = Regex.Split(title, @"<em>.*?</em>");

拆分成aa,<em>哈哈</em>,bb,<em>嘻嘻</em,cc

  1.   string[] str2 = Regex.Split(title,"(<em>.*?</em>)");

效果如下:

    

    其实很简单就是正则里边加一个()括起来就能取到它本身了


例子3:根据中文拆分字符串

  1. string str = "aa哈哈哈哈bb嘻嘻嘻嘻ccc";
  2. string[] str2 = Regex.Split(str, "([\u4e00-\u9fa5]+)");

效果如下:

 


正则表达式替换字符串


把重庆替换成<font>重庆</font>

  1. string content = "SS重庆xx";
  2. content = Regex.Replace(content, "重庆""<font>重庆</font>", RegexOptions.IgnoreCase);




统一把- **xxx**替换成### xxx
代码如下:

  1. Regex reg = new Regex(@"- \*\*(.*?)\*\*", RegexOptions.IgnoreCase);
  2. MatchCollection matchs = reg.Matches(tempContent);
  3. foreach (Match match in matchs)
  4. {
  5.     if (match.Success)
  6.     {
  7.         if (match.Groups.Count > 1
  8.         {
  9.             string beforeValue = match.Groups[0].Value;
  10.             string value = match.Groups[1].Value;
  11.             tempContent = tempContent.Replace(beforeValue, "### " + value);
  12.             //tempContent = Regex.Replace(tempContent, beforeValue, "### " + value, RegexOptions.IgnoreCase);
  13.             //tempContent = Regex.Replace(tempContent, @"- \*\*"+ value + @"\*\*", "### "+ value, RegexOptions.IgnoreCase);
  14.         }
  15.     }
  16. }


把 from [XX] as [y] 替换为 from [XX] as [y]  WITH (NOLOCK)。也就是需要在后面加上WITH (NOLOCK) 其中[XX]与[y]可以是任意英文与数字与下划线的组合名称
代码如下

  1. string input = "SELECT * from [tableName] as [alias]";
  2. string pattern = @"from\s+\[[a-zA-Z0-9_]+\]\s+as\s+\[[a-zA-Z0-9]+\]";
  3. string replacement = "$& WITH (NOLOCK)";
  4. string output = Regex.Replace(input, pattern, replacement);

其中,input 是需要替换的字符串;pattern 是匹配模式,使用了正则表达式来匹配符合要求的子字符串;replacement 是替换模板,使用 $& 表示将匹配到的子字符串保留,并加上 WITH (NOLOCK);最后调用 Regex.Replace() 方法完成替换操作,将结果保存在 output 变量中。



刚刚的问题除了支持把 from [XX] as [y] 替换为 from [XX] as [y]  WITH (NOLOCK)还能支持把JOIN [XX] as [y] 替换为 from [XX] as [y]  WITH (NOLOCK)
以下是可以同时匹配 "from [XX] as [y]" 和 "JOIN [XX] as [y]" 并替换为 "from [XX] as [y] WITH (NOLOCK)" 的 C# 正则表达式代码:

  1. string input = "SELECT * FROM [table1] JOIN [table2] AS [t2] WHERE [t2].[column1] > 10";
  2. string pattern = @"(?:FROM|JOIN)\s+\[[a-zA-Z0-9_]+\]\s+AS\s+\[[a-zA-Z0-9]+\]";
  3. string replacement = "$& WITH (NOLOCK)";
  4. string output = Regex.Replace(input, pattern, replacement);

其中,(?:FROM|JOIN) 表示匹配 "FROM" 或 "JOIN",而 ?: 则表示不捕获该组,只用于分组,以便后面的 $& 可以正确地取到要替换的子字符串。其余部分与之前的正则表达式类似,使用了 \[[a-zA-Z0-9]+\] 来匹配方括号内的任意英文字母和数字的组合名称。


请注意,在实际应用中,这种替换方式可能会带来一些风险,因为使用 WITH (NOLOCK) 可能会造成数据不一致或其他问题。建议在使用时谨慎考虑并进行充分测试。



正则表达式匹配特殊字符


加一个转义就行了。比如要匹配- **xxxx**这种格式的内容

  1. Regex.Replace(tempContent, @"- \*\*.*?\*\*""### 哈哈哈", RegexOptions.IgnoreCase);

注意前面要加一个@


正则表达式提取字符串


例如有一个字符串:"使用ef实现多对多关系配置"

我想使用ef作为一个关键字进行提取,提取ef的左边,ef本身,ef的右边。


我们就可以写一个正则表达式来提取:    Regex reg = new Regex("^(.*)(ef)(.*)$", RegexOptions.IgnoreCase);

正则表达式中用()将要提取的内容括起来,然后就可以通过Match的Groups属性来得到所有的提取元素,注意Groups的序号是从1开始的,0有特殊含义

  1. string content = "使用ef实现多对多关系配置";
  2. string query = "EF";//正则表达式可以动态的来
  3. List<string> search = new List<string>();
  4. Regex reg = new Regex("^(.*)(" + query + ")(.*)$", RegexOptions.IgnoreCase);
  5. Match match = reg.Match(content);
  6. if (match.Success)
  7. {
  8.     for (int i = 1; i < match.Groups.Count; i++)
  9.     {
  10.         search.Add(match.Groups[i].Value);
  11.     }
  12. }

效果如下:



使用js编写一个正则表达式可以提取出来*.png的内容


问题描述:使用js编写一个正则表达式可以提取出来*.png的内容,*表示任意字符,比如给定一个字符串"iconfont iconrole rolemanger.png",希望能够得到rolemanger.png

示例代码:

  1. const filename = "iconfont iconrole rolemanger.png";
  2. const regex = /[\w-]+\.(png)/;
  3. const result = regex.exec(filename);
  4. if (result !== null) {
  5.     console.log(result[0]); // 输出 rolemanger.png
  6. }





正则表达式写起来很简单就是头冷








欢迎加群讨论技术,1群:677373950(满了,可以加,但通过不了),2群:656732739。有需要软件开发,或者学习软件技术的朋友可以和我联系~(Q:815170684)

评价

css弹性盒子flex布局

css弹性盒子由于版本不同浏览器问题造成了一些不同的写法display:flexbox;在google浏览器中如果使用下面的写法就不行displa...

css图片和文字对齐问题

文字和图片写到一排经常会出现对不齐的问题 这样感觉图片会上来一点没有和文字对齐,如下图 但是如果修改下html结...

GitHub 上传项目

补充简化方法:登录git创建项目--&gt;拉取刚刚创建的项目--&gt;复制需要的代码进去--&gt;上传提交即可先拉取项目在上传代码...

NET core 使用 EF code First

下面这些内容很老了看这篇:https://www.tnblog.net/aojiancc2/article/details/5365 项目使用多层,把数据库访问...

Windows平台分布式架构实践 - 负载均衡

原文地址: https://www.cnblogs.com/atree/p/windows_loadbalancer.html 概述  最近.NET的世界开始闹腾了,微软官方终...

css实现简单矩形对话框

在前端做项目时,我们可能会遇到写对话框的需求,这次做视频会议页面就遇到了,记录下日后有个参照。//网页部分 &lt;divcla...

cAPS.NET 保存base64位格式的图片

publicvoidUpload() { //取出图片对应的base64位字符 stringimgBase=Request[&quot;imgBase&quot;]; //c#里边的base6...

使用OLEDB读取不同版本Excel的连接字符串设置

使用OleBD读取excel的时候,excel不同的版本,连接字符串的写法也会不一样。///&lt;summary&gt; ///读取excel ///&lt;/su...

vs2017 对 cOM 组件的调用返回了错误 HRESULT E_FAIL

vs2017添加引用报错 对 COM 组件的调用返回了错误 HRESULT E_FAIL 1.以管理员身份打开vs2017开发人员命令指示符 2...

分布式服务架构与微服务架构概念的区别与联系

分布式:分散压力。微服务:分散能力。当下理解分布式:不同模块部署在不同服务器上作用:分布式解决网站高并发带来问题集...

分布式-微服务-集群的区别

1.分布式将一个大的系统划分为多个业务模块,业务模块分别部署到不同的机器上,各个业务模块之间通过接口进行数据交互。区...

NPOI操作excel 2007/2010版本

HSSFWorkbook:是操作Excel2003以前(包括2003)的版本,扩展名是.xlsXSSFWorkbook:是操作Excel2007的版本,扩展名是.xlsx先...

这样学英语三个月超过你过去学三年

本文作者三年间从四级勉强及格到高级口译笔试210,口试232。找工作面试时给其口试的老外考官听了一分钟就说你的英语不用考...

EasyUI弹窗批量修改combogrid下拉框的值

JS方法//点击弹出批量修改框 UpdateLot:function(){ varrow=$(&quot;#dg&quot;).datagrid(&quot;getChecked&quot;); if(...

js与controller中分割字符串的方法

js: varstr=OpenRule; varstrs=newArray(); strs=str.split(&quot;,&quot;); for(vari=0;i&lt;strs.length;i++){ $(&q...

如何修改cSS中存在的element.style内联样式

改腾讯地图的时候调整了下样式,发现样式一直存在问题,修改style里面的值,一点用都没有,html中这个值还找不到是在哪里出...