正则表达式如何匹配包含某些词语、不包含某些词语

2016-09-06 09:44:55 +08:00
 Furylord

如,匹配:包含词语 [总行] [总部] ,不包含词语 [分行] [支行] [营业厅]

12088 次点击
所在节点    Python
22 条回复
lhbc
2016-09-06 09:47:52 +08:00
grep -P "(总行|)" | grep -v -P "(分行|支行|营业厅)"
按行匹配可以用这个
fising
2016-09-06 09:52:10 +08:00
不包含,就是包含的否定
knightdf
2016-09-06 10:06:50 +08:00
[] [^]
fancy967
2016-09-06 11:02:14 +08:00
关注一下,是不是只能通过两次判断来完成,能不能在一个正则表达式里就完成这两个判断呢?
murmur
2016-09-06 11:04:56 +08:00
@fancy967 一次匹配完成所有判断用 AC 自动机 这个是效率最高的 只要标记哪些词语属于匹配 哪些属于不匹配就可以了 还可以打分
whahuzhihao
2016-09-06 11:47:48 +08:00
@knightdf 这个不行吧 [^总行] 是不匹配有总或者有行的
knightdf
2016-09-06 12:39:33 +08:00
@whahuzhihao (?:)分组不就行了?
imn1
2016-09-06 13:10:07 +08:00
之前我发在 1L 的回复不见了,补一个
搜索 正则排除 就能找到你想要的,正则排除这样写
(?!(?:排除内容))(匹配内容)?
imn1
2016-09-06 13:15:37 +08:00
呃,上面的回复最后的问号多余的,我原来用来开关贪婪, copy 错了,后面的一对小括号按需,不是必须
(?!(?:分行|支行|营业厅)).*总行|总部.*
你试一下吧,我没法测试
whahuzhihao
2016-09-06 13:43:31 +08:00
@knightdf 那跟[] [^]有什么关系 环视里面也没用到中括号啊
douyang
2016-09-06 14:02:13 +08:00
cat 1.txt | grep "总行\|总部" | grep -v "分行\|支行\|营业厅"

过滤 grep
或者 |
取反 -v
转义 \

http://linux.51yip.com/search/grep
zhoulouzi
2016-09-06 14:14:38 +08:00
,匹配:包含词语 [总行] [总部] ,不包含词语 [分行] [支行] [营业厅]
Furylord
2016-09-06 14:36:15 +08:00
@imn1 这个不行哈
Furylord
2016-09-06 14:39:25 +08:00
没有能用一条正则表达式解决的办法?现在遇到的情况是,要对好多类型的名称作判断,全是 if "xxx" in name and "xxx" not in name 什么的,看着就烦也不好维护,希望找个正则表达式,我对正则表达式完全小白。。。。。网上搜了好久找不到解决的
dofy
2016-09-06 14:55:00 +08:00
包含和不包含要同时满足吗?
kkhaike
2016-09-06 15:00:43 +08:00
我想了下。。有“总行”的名字里会出现“分行”吗
dofy
2016-09-06 15:05:07 +08:00
看样子两个正则应该能满足要求:

```
// 伪代码
if reg1 match name and reg2 not match name
// 应该能搞定了吧
```

![]( )
SakuraKuma
2016-09-06 15:10:49 +08:00
/^.+(总[行|部])(?!(.*分行|.*支行|.*营业厅)).*$/
zhoulouzi
2016-09-06 15:33:00 +08:00
默认 分行 一定会出现在 总行后边 默认 总行 分行之间不会有任何字符的情况下: (总(行|部))(?!([分支]行|营业厅)) 可是正则是用来捕获了。~~
hyrious
2016-09-07 07:58:42 +08:00
大家好我不会正则
直接判字符串包含感觉更直觉和快

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/304210

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX