认证0级讲师
我来解释为什么上面呼氪的正则表达式可以成功 $number 把匹配的第number组替换成替换表达式,是在返回在模式匹配期间找到的所存储的最近的九个部分。每当产生一个带括号的成功匹配时,$1...$9 属性的值就被修改。一个正则表达式模式中可以指定任意多个带括号的子匹配,但只能存储最新的九个
比如正则表达式/(w )@(w ).(w )/g 待匹配文本adress helloworld@gmail.com 这里 = helloworld , S2 = gmail , =com
/(w )@(w ).(w )/g
adress helloworld@gmail.com
= helloworld , S2 = gmail , =com
replace中使用 $1 来引用所保存的第一个子匹配。如果有多个子匹配,则可以用 $2, $3 等继续引用 比如
public static void Main() { string s = "1 12 3 5"; s = Regex.Replace(s,@"(\d+)(?#这个是注释)","0",RegexOptions.Compiled|RegexOptions.IgnoreCase); Console.WriteLine(s); Console.ReadLine(); }
输出结果: 01 012 03 05
用你的文本来说,中间的汉字也就替换成$1,每次替换成$1,也就是对应的文字
知道答案了,Q群里面一位大神教得:QSTR("(.*)") 替换成 QSTR(tr("$1"))
我来解释为什么上面呼氪的正则表达式可以成功
$number 把匹配的第number组替换成替换表达式,是在返回在模式匹配期间找到的所存储的最近的九个部分。每当产生一个带括号的成功匹配时,$1...$9 属性的值就被修改。一个正则表达式模式中可以指定任意多个带括号的子匹配,但只能存储最新的九个
比如
正则表达式
/(w )@(w ).(w )/g
待匹配文本
adress helloworld@gmail.com
这里
= helloworld , S2 = gmail , =com
replace中使用 $1 来引用所保存的第一个子匹配。如果有多个子匹配,则可以用 $2, $3 等继续引用
比如
输出结果: 01 012 03 05
用你的文本来说,中间的汉字也就替换成$1,每次替换成$1,也就是对应的文字
知道答案了,Q群里面一位大神教得:QSTR("(.*)") 替换成 QSTR(tr("$1"))