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