亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

正則表達式匹配 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條經驗 獲得超4個贊

該點.還可以匹配反引號,因此該模式從匹配反引號開始,并且能夠匹配所有字符,直到它到達中的文字點[.]

無需使用非貪婪量詞,您可以使用否定字符類僅防止跨越反引號邊界。

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

正則表達式演示

星號*匹配 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 關注
  • 182 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號