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

Python 与 mysql 正规则不一样吗? 问个 mysql 数据替换的正规则。哪位朋友帮我看看下面 mysql 正规则有什么问题? 谢谢

  •  
  •   python30 · 2020-09-13 19:12:07 +08:00 · 1831 次点击
    这是一个创建于 1534 天前的主题,其中的信息可能已经有所发展或是发生改变。
    数据库里有一些下面格式的图片:
    <p><img alt="100 句常" title="100 句常,不犯错" src="http://pic.baidu.com/image/32778.jpg"></p>

    这图片地址里只有 http://pic.baidu.com 是不变的其它都是变的

    也有一些的图片

    <p><img alt="sadfasdfasdfdsf" title="dfasdfasdff" src="http://pic.google.com/image/32778.jpg"></p>

    现在只想把全部的 带 http://pic.baidu.com 这个网址的图片替换掉,也就是清除了。

    在 mysql 数据库里 ,怎么写正规则能完成这个 或者 有什么好的方法吗?

    update `bodytext` set body=replace(body, '<p><img alt=".*" title=".*" src="http://pic.baidu.com.*"></p>', '');

    上面是我写的。不成功。

    请哪位熟悉 mysql 的朋友帮我看看怎么改?
    谢谢。
    7 条回复    2020-09-14 13:05:13 +08:00
    zhoudaiyu
        1
    zhoudaiyu  
       2020-09-13 19:53:18 +08:00 via iPhone
    不太一样,有坑。
    herozzm
        2
    herozzm  
       2020-09-13 20:14:52 +08:00 via Android
    regex101 去看看 正则有好几种规则
    zhangysh1995
        3
    zhangysh1995  
       2020-09-13 20:27:11 +08:00
    @python30

    ````
    select REGEXP_LIKE('<p><img alt="." title="." src="http://pic.baidu.com.xxx"></p>',
    '<p><img alt="\\..*" title="\\..*" src="http://pic.baidu.com\\..*"></p>') as yes;
    ````
    zhangysh1995
        4
    zhangysh1995  
       2020-09-13 20:31:50 +08:00
    python30
        5
    python30  
    OP
       2020-09-13 23:28:43 +08:00
    @zhangysh1995
    谢谢
    我忘了说了
    我的 mysql 版本是 5.7
    不知道有什么方法能实现我想要的功能?
    royzheng
        6
    royzheng  
       2020-09-14 08:02:17 +08:00 via iPhone
    你用 python 写个更新的代码更新下不就得了?
    zhangysh1995
        7
    zhangysh1995  
       2020-09-14 13:05:13 +08:00
    @python30 5.7 没有原生正则支持,可以自己写个函数,参考 https://stackoverflow.com/questions/986826/how-to-do-a-regular-expression-replace-in-mysql

    不过我觉得楼上说的 Python 处理也挺好,先用 SQL 把满足条件的筛选出来返回给脚本,再用 SQL 更新回去。数据量不是太大的话应该还好。
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1174 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 23ms · UTC 18:38 · PVG 02:38 · LAX 10:38 · JFK 13:38
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.