为了账号安全,请及时绑定邮箱和手机立即绑定

正则表达式匹配 SQL 查询中的以下模式

正则表达式匹配 SQL 查询中的以下模式

慕村225694 2023-07-18 16:59:22
我正在尝试提取 MySQL 查询的部分内容以获取我想要的信息。我在Python中使用了这段代码/正则表达式:import re query = "SELECT `asd`.`ssss` as `column1`, `ss`.`wwwwwww` from `table`" table_and_columns = re.findall('\`.*?`[.]\`.*?`',query)我的预期输出:['`asd`.`ssss`', `ss`.`wwwwwww`']我的真实输出:['`asd`.`ssss`', '`column1`, `ss`.`wwwwwww`']有人可以帮助我并解释我哪里出错了吗?正则表达式应该只找到那些有两个字符串(如asd中间有一个点)的字符串。PS:我知道这不是一个有效的查询。
查看完整描述

3 回答

?
守着一只汪

TA贡献1872条经验 获得超3个赞

该点.还可以匹配反引号,因此该模式从匹配反引号开始,并且能够匹配所有字符,直到它到达中的文字点[.]

无需使用非贪婪量词,您可以使用否定字符类仅防止跨越反引号边界。

`[^`]*`\.`[^`]*`

正则表达式演示

星号*匹配 0 次或多次。如果必须至少有一个字符,并且不需要换行符和空格,则可以添加\s以防止匹配空白字符并使用+来匹配 1 次或多次。

`[^`\s]+`\.`[^`\s]+`

正则表达式演示Python演示

例如


import re

query = "SELECT `asd`.`ssss` as `column1`, `ss`.`wwwwwww` from `table`"

table_and_columns = re.findall('`[^`\s]+`\.`[^`\s]+`',query)

print(table_and_columns)

输出


['`asd`.`ssss`', '`ss`.`wwwwwww`']


查看完整回答
反对 回复 2023-07-18
?
炎炎设计

TA贡献1808条经验 获得超4个赞

问题是 .*?匹配任何字符(行终止符除外)甚至空格。另外,由于您已经在使用*,这意味着出现 0 次或无限次,不确定您是否需要使用?. 所以这似乎有效:

\`\S+\`[.]\`\S+\`

其中\S是任何非空白字符。您始终可以使用https://regex101.com检查正则表达式


查看完整回答
反对 回复 2023-07-18
?
MMMHUHU

TA贡献1834条经验 获得超8个赞

请尝试下面的正则表达式。.*从左到右的贪婪本质是导致问题的原因。
相反,您应该搜索 [^`]*

`[^`]*?`\.`[^`]*?`

演示


查看完整回答
反对 回复 2023-07-18
  • 3 回答
  • 0 关注
  • 101 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信