鱼C论坛

 找回密码
 立即注册
查看: 2611|回复: 5

[已解决]正则使用

[复制链接]
发表于 2020-11-2 16:32:14 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
x = ['123a_b123,123a_c123,123a_d123,123a_e123']


我想用正则匹配出a_c, a_d, a_e,不要a_b。怎么写?
最佳答案
2020-11-2 17:12:00
vcbeaut 发表于 2020-11-2 17:08
不要a_b,这个好像没有把b除开哦

这样的话就更简单了
  1. import re

  2. x = ['123a_b123,123a_c123,123a_d123,123a_e123']

  3. mo = re.findall(r'a_[^b]', x[0])
  4. print(mo)
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2020-11-2 16:58:29 | 显示全部楼层
  1. import re

  2. x = ['123a_b123,123a_c123,123a_d123,123a_e123']

  3. mo = re.findall(
  4.     r'''
  5.     (?<=\d{3})  # 非捕获分组,如果前面是三个数字就匹配后面的内容
  6.     .*?         # 非数字字符
  7.     (?=\d{3})   # 非捕获分组''',
  8.     x[0],
  9.     re.X)

  10. print(mo)
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-11-2 17:00:34 | 显示全部楼层
  1. import re

  2. x = ['123a_b123,123a_c123,123a_d123,123a_e123']

  3. mo = re.findall(r'[^1-3]{3}', x[0])
  4. print(mo)
复制代码

这个更简单一些
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-11-2 17:08:36 | 显示全部楼层

不要a_b,这个好像没有把b除开哦
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-11-2 17:12:00 | 显示全部楼层    本楼为最佳答案   
vcbeaut 发表于 2020-11-2 17:08
不要a_b,这个好像没有把b除开哦

这样的话就更简单了
  1. import re

  2. x = ['123a_b123,123a_c123,123a_d123,123a_e123']

  3. mo = re.findall(r'a_[^b]', x[0])
  4. print(mo)
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

 楼主| 发表于 2020-11-2 17:21:20 | 显示全部楼层
Brick_Porter 发表于 2020-11-2 17:12
这样的话就更简单了

大哥厉害
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-6-29 01:04

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表