第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問題,去搜搜看,總會(huì)有你想問的

正則表達(dá)式匹配 SQL 查詢中的以下模式

正則表達(dá)式匹配 SQL 查詢中的以下模式

慕村225694 2023-07-18 16:59:22
我正在嘗試提取 MySQL 查詢的部分內(nèi)容以獲取我想要的信息。我在Python中使用了這段代碼/正則表達(dá)式:import re query = "SELECT `asd`.`ssss` as `column1`, `ss`.`wwwwwww` from `table`" table_and_columns = re.findall('\`.*?`[.]\`.*?`',query)我的預(yù)期輸出:['`asd`.`ssss`', `ss`.`wwwwwww`']我的真實(shí)輸出:['`asd`.`ssss`', '`column1`, `ss`.`wwwwwww`']有人可以幫助我并解釋我哪里出錯(cuò)了嗎?正則表達(dá)式應(yīng)該只找到那些有兩個(gè)字符串(如asd中間有一個(gè)點(diǎn))的字符串。PS:我知道這不是一個(gè)有效的查詢。
查看完整描述

3 回答

?
守著一只汪

TA貢獻(xiàn)1872條經(jīng)驗(yàn) 獲得超4個(gè)贊

該點(diǎn).還可以匹配反引號(hào),因此該模式從匹配反引號(hào)開始,并且能夠匹配所有字符,直到它到達(dá)中的文字點(diǎn)[.]

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

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

正則表達(dá)式演示

星號(hào)*匹配 0 次或多次。如果必須至少有一個(gè)字符,并且不需要換行符和空格,則可以添加\s以防止匹配空白字符并使用+來匹配 1 次或多次。

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

正則表達(dá)式演示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`']


查看完整回答
反對(duì) 回復(fù) 2023-07-18
?
炎炎設(shè)計(jì)

TA貢獻(xiàn)1808條經(jīng)驗(yàn) 獲得超4個(gè)贊

問題是 .*?匹配任何字符(行終止符除外)甚至空格。另外,由于您已經(jīng)在使用*,這意味著出現(xiàn) 0 次或無限次,不確定您是否需要使用?. 所以這似乎有效:

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

其中\S是任何非空白字符。您始終可以使用https://regex101.com檢查正則表達(dá)式


查看完整回答
反對(duì) 回復(fù) 2023-07-18
?
MMMHUHU

TA貢獻(xiàn)1834條經(jīng)驗(yàn) 獲得超8個(gè)贊

請(qǐng)嘗試下面的正則表達(dá)式。.*從左到右的貪婪本質(zhì)是導(dǎo)致問題的原因。
相反,您應(yīng)該搜索 [^`]*

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

演示


查看完整回答
反對(duì) 回復(fù) 2023-07-18
  • 3 回答
  • 0 關(guān)注
  • 179 瀏覽
慕課專欄
更多

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)