麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 編程 > Regex > 正文

coolcode轉(zhuǎn)SyntaxHighlighter與Mysql正則表達(dá)式實現(xiàn)分析

2020-03-16 21:11:51
字體:
供稿:網(wǎng)友
blog的代碼高亮插件原來是coolcode的,coolcode的高亮插件確實很酷,顯示效果也很棒,但是占用的位子太大了。
 
 
最近,我抽空改成SyntaxHighlighter。由于coolcode插件的開頭標(biāo)簽是 
<coolcode> 
或者[coolcode]這樣的,而SyntaxHighlighter是 

[code lang="php"] 
這樣的(或者其他)。遂只能想辦法把老的格式轉(zhuǎn)化成新的格式。當(dāng)然,肯定用到正則表達(dá)式了。 
原來的代碼高亮開頭標(biāo)識為 

<coolcode lang="php" download="123.php" linenum="on"><coolcode lang="php" linenum="off"><coolcode lang="php"> 
這種類型的, 
而SyntaxHighlighter的標(biāo)識為 

[code lang="php"] 
那根據(jù)要求寫的正則表達(dá)式為 

<coolcode lang="[a-z]+".*?> 
解釋一下 
復(fù)制代碼代碼如下:

[a-z]+ 匹配 php,javascript,cpp,sql,css 等,后面的.*?中的 .表示任何除了換行之外的字符,而*表示0次或者無數(shù)次,*+這些表述次數(shù)的符號后面接的?標(biāo)識非貪婪模式 

coolcode轉(zhuǎn)SyntaxHighlighter與Mysql正則表達(dá)式實現(xiàn)分析
看圖,這個正則可以實現(xiàn)上述要求了。 

但是,問題還沒解決,我們還有一種情況沒考慮,那就是 
<coolcode 
后面不一定接的就是lang="php"這樣的屬性啊,有可能是download,也有可能是linenum="on/off"啊,所以,我們的正則還需要改。 
CFC4N把正則改為 
<coolcode.*?lang="[a-z]+".*?> 
截圖如下 
coolcode轉(zhuǎn)SyntaxHighlighter與Mysql正則表達(dá)式實現(xiàn)分析
細(xì)心的朋友可能看出來圖中匹配的紅色框內(nèi)多出了 
<coolcode 
,意思也就是說,前面的 

<coolcode> 
需要排除掉。如何排除呢?聰明的你肯定立刻想到.這個萬能字符替換成非<>兩個符號的規(guī)則,好,CFC4N立刻修改一下。 
修改之后的正則為 

<coolcode.*?lang="[a-z]+".*?> 
果然,匹配正常了。結(jié)果見截圖。 
coolcode轉(zhuǎn)SyntaxHighlighter與Mysql正則表達(dá)式實現(xiàn)分析
到這里,問題似乎解決了,可是,當(dāng)初糊涂的我,把coolcode的兩種開頭標(biāo)識都用了,那就是 

<coolcode 
和[coolcode,那么,看官您認(rèn)為這個正則該如何改寫呢? 
沒錯,無非就是開頭,結(jié)尾的標(biāo)識考慮兩種情況<和[,那么正則就好改了。(別忘了排除規(guī)則里的符號哦) 
[</[]coolcode[^<>/[/]]*?lang="[a-z]+"[^<>/[/]]*?[>/]] 
嗯,好,我們來看下效果: 
coolcode轉(zhuǎn)SyntaxHighlighter與Mysql正則表達(dá)式實現(xiàn)分析
很好很完美。 
下面,就可以去執(zhí)行了。 
可是,我遇到一個很意外的事情。居然發(fā)現(xiàn)老的代碼里包含這樣的格式 
[coolcode linenum=/"off/" lang=/"cpp/"]<coolcode download=/"/" lang=/"cpp/" linenum="off"> 
呃,問題在這里了,只是多了個轉(zhuǎn)義字符/罷了,那么,改起來,也簡單。也就是允許/出現(xiàn)0次或者一次,而標(biāo)識0次或者1次的符號為?,那么我們直接在/后面加個?,也就是改成這樣/?就可以了嗎? 
顯然,不是。在正則表達(dá)式里,/也表示轉(zhuǎn)義,那么,匹配/的話,也得轉(zhuǎn)義一下/,則應(yīng)該為//? 這樣才對。 
修改后正則為 
[</[]coolcode[^<>/[/]]*?lang=//?"[a-z]+//?"[^<>/[/]]*?[>/]] 
匹配結(jié)果見下圖: 
coolcode轉(zhuǎn)SyntaxHighlighter與Mysql正則表達(dá)式實現(xiàn)分析
現(xiàn)在,大功告成了。我們可以進行轉(zhuǎn)換了。關(guān)于轉(zhuǎn)換,我們可以用兩種方法。 

•Mysql的REPLACE函數(shù),單個的去替換 
<coolcode lang="php/cpp/javascript/sql/css等" download="name" linenum="on/off"> 
為對應(yīng)的 
[code lang="php/cpp/javascript/sql/css等"] 
,這樣操作,省的去寫程序,取出,替換,再寫入了,缺點是量大,手工也挺累,體力活。mysql僅僅支持正則查詢,不支持正則查詢的替換,我們也可以構(gòu)造聯(lián)合嵌套的SQL來替換正則匹配的字符串,但是無法取出php/cpp/javascrip這樣的語言標(biāo)記,替換為新的語言標(biāo)記。也就是說,mysql不支持正則表達(dá)式的反向引用。 

•PHP讀數(shù)據(jù)庫,替換,再寫入。PHP的preg_replace函數(shù)支持反向引用(preg_replace不支持自定義組名的反向引用),我們只好寫個查詢語句,查詢包含coolcode標(biāo)識的文章,然后再替換,當(dāng)然,直接查詢包含coolcode的文章可能太多,我們也可以寫個MYSQL支持的POSIX正則引擎的表達(dá)式,來匹配使用coolcode標(biāo)簽的文章,再來替換,寫入。以減少文章的操作量。當(dāng)然正則表達(dá)式也會浪費很大的資源。 
當(dāng)然,在PHP代碼的preg_replace函數(shù)使用上面的正則,進行反向引用時,需要對正則稍作修改。給lang=""中間的一個組名。正則修改為 
[</[]coolcode[^<>/[/]]*?lang=//?"([a-z]+//?)"[^<>/[/]]*?[>/]] 
PHP的替換代碼為 
$contents = preg_replace('/[<|[]coolcode[^>[/]]*?lang=////?"([^"]+?)////?"[^>[/]]*?[>|/]]/i','[code lang="//1"',$contents); 
其中正則的i修飾符標(biāo)識不區(qū)分大小寫。 
coolcode轉(zhuǎn)SyntaxHighlighter與Mysql正則表達(dá)式實現(xiàn)分析
還有,別忘記了coolcode的結(jié)束標(biāo)識和[/coolcode]要替換成[/code]。 
mysql里執(zhí)行兩句sql即可 
復(fù)制代碼代碼如下:

UPDATE wp_posts SET post_content = REPLACE(post_content,'</coolcode>','[//code]'); //注意后面多了個反斜杠,記得去掉 
UPDATE wp_posts SET post_content = REPLACE(post_content,'[/coolcode]','[//code]'); //注意后面多了個反斜杠,記得去掉 

總結(jié): 
本文牽扯的正則表達(dá)式并無高級用法,都是平常很簡單的用法。關(guān)于PCRE引擎正則表達(dá)式的遞歸(迭代),組命名,反向引用,零寬斷言等,CFC4N會在以后的時間里,找合適的例子寫出來。當(dāng)然,這些高級用法,CFC4N在幫朋友寫的正則表達(dá)式里已經(jīng)用到了,大家可以看看,歡迎批評和指點。 
PS:如果需要coolcode轉(zhuǎn)SyntaxHighlighter的完整PHP程序,留言即可,我抽空寫出來。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 成人在线a | 亚洲激情91| 哪里可以看免费的av | 性 毛片 | 91精品国产九九九久久久亚洲 | 97超碰资源站 | 亚洲一区在线免费视频 | 久久久久久久一区二区三区 | 色欧美视频 | 福利免费观看 | 日韩av在线网 | 999精品国产 | 色999久久久精品人人澡69 | 视频一区二区三区在线 | 狼人狠狠干 | 性欧美xxxx免费岛国不卡电影 | 精品国产欧美一区二区 | 午夜精品老牛av一区二区三区 | 黄色的视频在线观看 | 国产羞羞网站 | 黄色网址在线免费播放 | 精品久久久久久久久久久久久 | 日日草视频| 中国av中文字幕 | 91一区二区三区久久久久国产乱 | 日韩中文字幕一区二区三区 | 久久久久夜色精品国产老牛91 | 午夜精品久久久久久久爽 | 色毛片 | 亚洲片在线观看 | 国产精品高潮视频 | 亚洲精品7777 | 男女羞羞视频在线观看免费 | 伊人二本二区 | 久久情爱网 | 一级毛片在线免费播放 | 最新亚洲国产 | 欧美日韩高清不卡 | 免费毛片在线视频 | 91亚洲免费视频 | 99精品视频99 |