吾爱破解 - 52pojie.cn

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 1367|回复: 16
收起左侧

[已解决] 一个正则匹配求助

 关闭 [复制链接]
zheng10072 发表于 2020-6-17 10:04
本帖最后由 zheng10072 于 2020-6-17 13:51 编辑

语句:update xxx set a=1,b =d, c  =y where 1=1 and bb=a;
我想匹配到 a=1,b =d, c  =y 中的a b c
请问大佬们这个正则怎么写?


((?<k>[\w\d]+)\s*=\s*(?<v>[\w\d]+)\s*,?(?=(,|where)))+
这个可以

发帖前要善用论坛搜索功能,那里可能会有你要找的答案或者已经有人发布过相同内容了,请勿重复发帖。

依旧沉沉 发表于 2020-6-17 10:11
(.*?)=\d+
试试行不行
 楼主| zheng10072 发表于 2020-6-17 10:15
明明很皮 发表于 2020-6-17 10:22
Mr.A 发表于 2020-6-17 10:26
[a-z]=\d
 楼主| zheng10072 发表于 2020-6-17 10:27

我这个例子举的不好,字段不一定是数字
update xxx set a=1,b =d, c  =y where 1=1 and bb=a;
明明很皮 发表于 2020-6-17 10:29
zheng10072 发表于 2020-6-17 10:27
我这个例子举的不好,字段不一定是数字
update xxx set a=1,b =d, c  =y where 1=1 and bb=a;
...

最好是提供实际需求,针对实际需求来写正则比较好
明明很皮 发表于 2020-6-17 10:31
zheng10072 发表于 2020-6-17 10:27
我这个例子举的不好,字段不一定是数字
update xxx set a=1,b =d, c  =y where 1=1 and bb=a;
...

如果一个正则表达式完成不了,那就两个正则了,先取set -- where之间匹配出来,然后再匹配abc也可以
头像被屏蔽
要帅 发表于 2020-6-17 10:37
提示: 作者被禁止或删除 内容自动屏蔽
 楼主| zheng10072 发表于 2020-6-17 10:38
明明很皮 发表于 2020-6-17 10:29
最好是提供实际需求,针对实际需求来写正则比较好

实际需求是我想把update语句自动转成 select备份语句,现在就差 set 的字段提取不出来了。正则简单处理后用程序再处理可以弄出来,想顺便学习下正则
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

返回列表

RSS订阅|小黑屋|处罚记录|联系我们|吾爱破解 - LCG - LSG ( 京ICP备16042023号 | 京公网安备 11010502030087号 )

GMT+8, 2024-11-27 15:38

Powered by Discuz!

Copyright © 2001-2020, Tencent Cloud.

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