类似这样的字符串,格式固定是
任意数量的英文字母 + . + 任意数量的英文字母 + . + 任意数量的英文字母 + . + 任意数量的英文字母
比如这样 dkfj.wer.dkfjj.sldkf
我只想要最后 sldkf 这个字符串,如何用正则匹配过滤掉前面的 dkfj.wer.dkfjj.
类似这样的字符串,格式固定是
任意数量的英文字母 + . + 任意数量的英文字母 + . + 任意数量的英文字母 + . + 任意数量的英文字母
比如这样 dkfj.wer.dkfjj.sldkf
我只想要最后 sldkf 这个字符串,如何用正则匹配过滤掉前面的 dkfj.wer.dkfjj.
1
czyt Jul 22, 2022
试试 (?<=\w+\.)\w+$
|
2
wxf666 Jul 22, 2022
$ sed 's/^.*\.//' <<<'dkfj.wer.dkfjj.sldkf'
输出: sldkf |
3
Hardrain Jul 22, 2022
`[a-zA-Z]+\.[a-zA-Z]+\.[a-zA-Z]+\.([a-zA-Z]+)`
取$1 如果仅小写, 替换`a-zA-Z`为`a-z` ``` $ cat /tmp/sample.txt dkfj.wer.dkfjj.sldkf $ sed -Ee 's/[a-zA-Z]+\.[a-zA-Z]+\.[a-zA-Z]+\.([a-zA-Z]+)/\1/' /tmp/sample.txt sldkf ``` |
4
wxf666 Jul 22, 2022
仅捕获想要的字符串:
[^.]*$ |
5
haodingzan Jul 23, 2022
看起来是要做数据清洗,提取需要的值。
找个支持正则的编辑器,比如 VS Code 查找:^.*\. --> 从整句开头开始查找所有内容,结尾为一个“.” 替换:空 剩下的就是你要的了 |
6
MajestySolor OP |
7
masker Jul 23, 2022 via Android
正向断言
|
8
hitaoguo Jul 23, 2022
这个需求不一定非要正则啊,split 拿最后
|
9
512357301 Jul 23, 2022 via Android
|
10
zhuweiyou Jul 24, 2022
这不需要正则, split('.').pop() 就完事了
|