正则表达式在文本中的应用,正则表达式的原理
很多朋友对于正则表达式在文本中的应用和正则表达式的原理不太懂,今天就由小编来为大家分享,希望可以帮助到大家,下面一起来看看吧!
一、什么函数可以提取文本中的数字
find函数可以提取文本中的数字。
1.用find函数案列,i要用双引号,且在英文状态下输入。如果是2,5等数字就不要。
2.find函数一般和其他函数结合使用。通过知find函数定位,然后提取邮箱中的账号。输入公式=LEFT(A2,FIND("@",A2,1)-1)
可以看出使用left函数提取@前面的位数。
3.find函数使用的注意点,中有两个i,只返回第一个i的位置
二、正则表达式怎么给某个字符定义
1、\cx 匹配由x指明的控制字符。例如,\cM匹配一个Control-M或回车符。x的值必须为A-Z或a-z之一。否则,将c视为一个原义的‘c’字符。
2、\f 匹配一个换页符。等价于\x0c和\cL。
3、\n 匹配一个换行符。等价于\x0a和\cJ。
4、\r 匹配一个回车符。等价于\x0d和\cM。
5、\s 匹配任何空白字符,包括空格、制表符、换页符等等。等价于[\f\n\r\t\v]。
6、\S 匹配任何非空白字符。等价于[^\f\n\r\t\v]。
7、\t 匹配一个制表符。等价于\x09和\cI。
8、\v 匹配一个垂直制表符。等价于\x0b和\cK。
9、$ 匹配输入字符串的结尾位置。如果设置了RegExp对象的Multiline属性,则$也匹配‘\n’或‘\r’。要匹配$字符本身,请使用\$。
10、() 标记一个子表达式的开始和结束位置。子表达式可以获取供以后使用。要匹配这些字符,请使用\(和\)。
11、* 匹配前面的子表达式零次或多次。要匹配*字符,请使用\*。
12、+ 匹配前面的子表达式一次或多次。要匹配+字符,请使用\+。
13、. 匹配除换行符\n之外的任何单字符。要匹配.,请使用\。
14、[ 标记一个中括号表达式的开始。要匹配[,请使用\[。
15、? 匹配前面的子表达式零次或一次,或指明一个非贪婪限定符。要匹配?字符,请使用\?。
16、\ 将下一个字符标记为或特殊字符、或原义字符、或向后引用、或八进制转义符。例如,‘n’匹配字符‘n’。’\n’匹配换行符。序列‘\\’匹配“\”,而‘\(’则匹配“(”。
17、^ 匹配输入字符串的开始位置,除非在方括号表达式中使用,此时它表示不接受该字符集合。要匹配^字符本身,请使用\^。
18、{ 标记限定符表达式的开始。要匹配{,请使用\{。
19、| 指明两项之间的一个选择。要匹配|,请使用\|。* 匹配前面的子表达式零次或多次。例如,zo*能匹配“z”以及“zoo”。*等价于{0,}。
20、+ 匹配前面的子表达式一次或多次。例如,’zo+’能匹配“zo”以及“zoo”,但不能匹配“z”。+等价于{1,}。
21、? 匹配前面的子表达式零次或一次。例如,”do(es)?”可以匹配“do”或“does”中的”do”。?等价于{0,1}。
22、{n} n是一个非负整数。匹配确定的n次。例如,’o{2}’不能匹配“Bob”中的‘o’,但是能匹配“food”中的两个o。
23、{n,} n是一个非负整数。至少匹配n次。例如,’o{2,}’不能匹配“Bob”中的‘o’,但能匹配“foooood”中的所有o。’o{1,}’等价于‘o+’。’o{0,}’则等价于‘o*’。
24、{n,m} m和n均为非负整数,其中n<=m。最少匹配n次且最多匹配m次。例如,”o{1,3}”将匹配“fooooood”中的前三个o。’o{0,1}’等价于‘o?’。请注意在逗号和两个数之间不能有空格。
三、正则表达式,匹配某字符开头
^表示文本开始;$表示文本结束;
四、正则表达式的原理
1、正则表达式(RegularExpression)是一种用来匹配特定模式文本的模式匹配语言,它可以用于文本搜索、字符串匹配、文本替换等任务中。正则表达式的原理基于有限状态自动机(FiniteStateAutomata)的理论,该理论描述了一种计算模型,它使用有限个状态和转移函数对输入的字符序列进行处理和识别。
2、正则表达式的基本原理是使用特定的字符和操作符定义一个模式,然后使用该模式在文本中匹配符合该模式的字符串。在正则表达式中,常用的字符包括字母、数字、特殊符号等,而操作符则用于定义匹配规则,例如‘*’、‘+’、‘?’等,用于分组、限定数量、替代等操作。
3、在匹配过程中,正则表达式将文本序列按照规则分解成单个字符,并按照预定义的规则进行匹配。如果匹配成功,则返回匹配结果;如果匹配失败,则返回错误信息。在实现中,正则表达式通常会将模式转换成一个有限状态自动机,然后使用该自动机在文本序列上进行匹配。由于有限状态自动机具有高效的匹配性能,因此正则表达式在实际应用中有着广泛的应用。
五、正则表达式@\
1、我们一个字符一个字符的进行分析
2、(.*?)匹配任意长度的任意字符但是后面的?表示采用非贪婪模式也就是说在遇到/字符之前的位置上尽可能多的匹配而不是一直匹配到最后一个/字符
3、([\w\d])\w表示任意字母或数字\d表示任意数字所以这里的[\w\d]写的有些问题因为[]内的内容只匹配一个字符所以([\w\d])和(\w)的意义应该是一样的
4、这个正则表达式应该可以改写为:
好了,文章到此结束,希望可以帮助到大家。
——————————————小炎智能写作工具可以帮您快速高效的创作原创优质内容,提高网站收录量和各大自媒体原创并获得推荐量,点击右上角即可注册使用
相关新闻推荐
- 正则表达式在易语言怎么用(如何使用正则表达式) 2023-11-30
- 正则表达式在文本中的应用,正则表达式的原理 2023-11-30
- 正则表达式在手册中如何查?正则表达式符号解释 2023-11-30
- 正则表达式在字符串开头加 如何用Python正则表达式去匹配汉字加字母加数字的字符串 2023-11-30
- 正则表达式在字符串中用写,使用正则表达式exec获取字符串中的汉字 2023-11-30
- 正则表达式在哪文件夹显示(linux查找文件夹命令) 2023-11-30