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
ohmyzsh
V2EX  ›  Python

Python 如何使用正则提取中间文本

  •  
  •   ohmyzsh · 2018-01-01 13:10:07 +08:00 · 2949 次点击
    这是一个创建于 2511 天前的主题,其中的信息可能已经有所发展或是发生改变。

    文本如下:

    A 公司生产的 aa 产品,B 公司生产的 bb 产品,C 公司生产的 cc 产品,...

    用 Python 该怎么把所有的产品名称( aa、bb、cc 等)提取出来保存为列表呢?谢谢!

    (product = re.findall(r"生产的(.*),", article) 为啥不对呢?)
    11 条回复    2018-01-04 11:31:48 +08:00
    welkinzh
        1
    welkinzh  
       2018-01-01 13:21:17 +08:00
    英文和中文之间有空格吧,还有逗号前面要加个反斜杠
    radiocontroller
        2
    radiocontroller  
       2018-01-01 13:34:28 +08:00   ❤️ 1
    (.*?)这里加个问号(懒惰匹配)
    ohmyzsh
        3
    ohmyzsh  
    OP
       2018-01-01 14:01:19 +08:00
    @radiocontroller 多谢。
    ohmyzsh
        4
    ohmyzsh  
    OP
       2018-01-01 14:04:02 +08:00
    @welkinzh 哦,没有空格,按照 #2 的方法解决了
    Xiaobaixiao
        5
    Xiaobaixiao  
       2018-01-02 17:40:32 +08:00
    (?<=生产的).+(?=产品)
    ohmyzsh
        6
    ohmyzsh  
    OP
       2018-01-03 09:33:50 +08:00
    @Xiaobaixiao 试了下,您这个输出是空值
    Xiaobaixiao
        7
    Xiaobaixiao  
       2018-01-03 13:15:36 +08:00
    @ohmyzsh 结合 #1 #2 的 那就是:(?<=生产的\s)(.*?)(?=\s 产品)
    ohmyzsh
        8
    ohmyzsh  
    OP
       2018-01-03 15:38:29 +08:00
    @Xiaobaixiao 还是空值😅
    ohmyzsh
        9
    ohmyzsh  
    OP
       2018-01-03 15:39:18 +08:00
    @Xiaobaixiao 生产的(.*?),

    #2 的这个可以
    Xiaobaixiao
        10
    Xiaobaixiao  
       2018-01-03 16:36:09 +08:00
    @ohmyzsh 不会吧……
    >>> article='''A 公司生产的 aa 产品,B 公司生产的 bb 产品,C 公司生产的 cc 产
    品'''
    >>> re.findall('(?<=生产的\s)(.*?)(?=\s 产品)',article)
    ['aa', 'bb', 'cc']
    ohmyzsh
        11
    ohmyzsh  
    OP
       2018-01-04 11:31:48 +08:00
    @Xiaobaixiao 把 re.findall('(?<=生产的\s)(.*?)(?=\s 产品)',article) 产品前的空格去掉可以了,多谢回复,新年好!
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2851 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 25ms · UTC 07:43 · PVG 15:43 · LAX 23:43 · JFK 02:43
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.