V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
推荐学习书目
Learn Python the Hard Way
Python Sites
PyPI - Python Package Index
http://diveintopython.org/toc/index.html
Pocoo
值得关注的项目
PyPy
Celery
Jinja2
Read the Docs
gevent
pyenv
virtualenv
Stackless Python
Beautiful Soup
结巴中文分词
Green Unicorn
Sentry
Shovel
Pyflakes
pytest
Python 编程
pep8 Checker
Styles
PEP 8
Google Python Style Guide
Code Style from The Hitchhiker's Guide
fan2006
V2EX  ›  Python

帮我看下这个正则表达式

  •  
  •   fan2006 · 2018-12-28 12:15:29 +08:00 · 2106 次点击
    这是一个创建于 2156 天前的主题,其中的信息可能已经有所发展或是发生改变。
    下面这个正则:
    re.findall(r'(?<!数量)\d+','数量 123 单价 45 金额 5535')
    得到了结果:
    ['23', '45', '5535']
    我想以否定的模式来写,就是不想提取数量后面的数值,在结果的 list 里面数量那个 23 不应该出现的。
    10 条回复    2019-01-04 13:33:12 +08:00
    fan2006
        1
    fan2006  
    OP
       2018-12-28 12:36:19 +08:00
    自己研究写了一个出来。python 3
    re.findall(r'[一-龥]+(?<!数量)(\d+)','数量 123 单价 45 金额 5535')
    结果:
    ['45', '5535']
    no1xsyzy
        2
    no1xsyzy  
       2018-12-28 12:41:57 +08:00   ❤️ 1
    因为匹配了 “数量 1 ”
    re.findall(r'(?<!数量)\s(\d+)','数量 123 单价 45 金额 5535')
    fan2006
        3
    fan2006  
    OP
       2018-12-28 12:50:15 +08:00
    @no1xsyzy 嗯,非常感谢大大
    nekoneko
        4
    nekoneko  
       2018-12-28 13:25:53 +08:00
    数量和\d 中间加个空格试试
    fan2006
        5
    fan2006  
    OP
       2018-12-28 13:30:30 +08:00
    @nekoneko 其实字符串之间没有空格,我那个还是能起作用
    nekoneko
        6
    nekoneko  
       2018-12-28 13:40:04 +08:00
    @fan2006 (?<!数量\d*)\d+
    imn1
        7
    imn1  
       2018-12-28 13:52:14 +08:00
    空格是 V2 后台加的么?
    python 的 re.findall 总有难以预想的情况
    正常理解,「(?<!数量)\d+」和「(?<!数量)(\d+)」是一样的,似乎 python 里面有优先级的区别
    fan2006
        8
    fan2006  
    OP
       2018-12-28 14:31:21 +08:00
    @nekoneko 你这个报错。提示 look-behind requires fixed-width pattern
    fan2006
        9
    fan2006  
    OP
       2018-12-28 14:37:07 +08:00
    @imn1 确实后台加的。。\d+没括号就会捕捉带文字数值,应该是匹配整个 pattern 作为分组,带了括号就会只取得数字匹配括号分组。
    nekoneko
        10
    nekoneko  
       2019-01-04 13:33:12 +08:00
    @fan2006 编译器的锅好像,不支持不定长度。(?<!数量[0-9]{0,100000})[0-9]+这样就可以了
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   5257 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 32ms · UTC 08:53 · PVG 16:53 · LAX 00:53 · JFK 03:53
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.