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

这个正则怎么写啊?

  •  
  •   llsquaer · 2020-10-31 13:21:34 +08:00 · 2913 次点击
    这是一个创建于 1244 天前的主题,其中的信息可能已经有所发展或是发生改变。

    用的 python

    假设有一段文字

    aaa.bbb.ccc.xxx(ddd.fffssss.eeee)
    

    所有字符都是不等长的单词..需要做的是.提取出如下格式内容

    xxx(ddd.fffssss.eeee)
    

    提取出 . 号到 ( 号 和 ()号内 的文字..

    这样的正则怎么写啊????

    9 条回复    2020-11-02 11:11:36 +08:00
    gwy15
        1
    gwy15  
       2020-10-31 13:25:39 +08:00
    \.(\w+\(.+\))
    Fechin
        2
    Fechin  
       2020-10-31 13:28:59 +08:00
    (?<=\.)[^\.]+\([^)]+\)
    llsquaer
        3
    llsquaer  
    OP
       2020-10-31 14:08:47 +08:00
    @gwy15 十分感谢啊. 为什么把 \w+ 改为 .+ 就变成了从开始位置的 . 开始了呢? 之前一直用 . 代表任意字符....所以之前一直没匹配上..
    natsukage
        4
    natsukage  
       2020-10-31 14:58:07 +08:00   ❤️ 2
    @llsquaer #3 因为正则表达式引擎在匹配字符串和表达式时,是从前向后逐个扫描字符串中的字符,并判断是否与表达式符合的。 .bbb.ccc.xxx 和 .xxx 虽然都可以匹配 .+,但是正则表达式扫描的时候,从 .bbb 就已经开始能够正常匹配,一直持续到后面的整个 .bbb.ccc.xxx(ddd.fffssss.eeee) 结束匹配完成。虽然.ccc.xxx(ddd.fffssss.eeee)和.xxx(ddd.fffssss.eeee)也能完成匹配,但是因为.bbb.ccc.xxx(ddd.fffssss.eeee)是先来的,所以正则表达式会娶先来的这个作为最终结果。
    如果想要解决这个问题,要么就是想办法让.bbb.ccc.xxx 和.ccc.xxx 不满足匹配,1 楼的解法就是这么做的,通过 \w 取代 . ,这样.xxx 就是第一个满足匹配的前缀了,因此能够正常匹配到你想要的结果。
    要么就是提前把前面的部分( aaa.bbb.ccc.)全部用非捕获组匹配掉,然后在剩下的部分里匹配你想要匹配的内容,例如(?:.+\.)(?<match>.+?\([^)]+\))
    dorothyREN
        5
    dorothyREN  
       2020-10-31 19:04:29 +08:00
    grep -o "[a-zA-Z]*(.*)"
    dorothyREN
        6
    dorothyREN  
       2020-10-31 19:04:56 +08:00
    ```
    [root@db ~]# grep -o "[a-zA-Z]*(.*)" a
    xxx(ddd.fffssss.eeee)
    [root@db ~]#
    ```
    dorothyREN
        7
    dorothyREN  
       2020-10-31 19:32:23 +08:00
    re.search(r"\.[^.]*\(.*\)", a)
    huyangabc
        8
    huyangabc  
       2020-10-31 20:36:16 +08:00
    \.(\w+\(.*\))
    llsquaer
        9
    llsquaer  
    OP
       2020-11-02 11:11:36 +08:00
    @natsukage
    @dorothyREN
    谢谢你们俩的解答...通过测试,终于算是搞明白了.
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   我们的愿景   ·   实用小工具   ·   956 人在线   最高记录 6543   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 28ms · UTC 21:36 · PVG 05:36 · LAX 14:36 · JFK 17:36
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.