亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > Regex > 正文

coolcode轉SyntaxHighlighter與Mysql正則表達式實現分析

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

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

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

[code lang="php"] 
那根據要求寫的正則表達式為 

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

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

coolcode轉SyntaxHighlighter與Mysql正則表達式實現分析
看圖,這個正則可以實現上述要求了。 

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

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

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

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

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

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

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

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产亚洲人成a一在线v站| 777777777亚洲妇女| 欧美成人午夜激情视频| 久久久久久12| 国产精品精品久久久| 欧美精品在线视频观看| 欧美专区国产专区| 国产精品三级久久久久久电影| 国产精品三级美女白浆呻吟| 亚洲国产精品福利| 国模gogo一区二区大胆私拍| 亚洲人成网站色ww在线| 91高清免费视频| 69久久夜色精品国产7777| 欧美在线精品免播放器视频| 成人国产精品久久久久久亚洲| 久久欧美在线电影| 国产激情999| 国产亚洲一区二区精品| 久久综合国产精品台湾中文娱乐网| 亚洲福利视频久久| 亚洲变态欧美另类捆绑| 午夜精品99久久免费| 日韩视频免费大全中文字幕| 日韩免费中文字幕| 日韩黄色在线免费观看| 国产精品av在线| 九九视频直播综合网| 日韩在线www| 亚洲国产精彩中文乱码av| 国产精品电影观看| 性亚洲最疯狂xxxx高清| 欧美高清不卡在线| 亚洲精品少妇网址| 91免费精品视频| 4p变态网欧美系列| 18性欧美xxxⅹ性满足| 性色av一区二区三区红粉影视| 国产免费一区二区三区香蕉精| 亚洲欧美激情一区| 国产精品视频99| 欧美午夜性色大片在线观看| 亚洲欧美另类人妖| 午夜精品免费视频| 日韩电视剧免费观看网站| 久热精品视频在线观看一区| 亚洲精品美女免费| 日韩一区二区在线视频| 国产精品中文久久久久久久| 国产+成+人+亚洲欧洲| 91中文精品字幕在线视频| 精品视频在线播放| 亚洲欧美一区二区三区四区| 亚洲最大激情中文字幕| 97精品在线观看| 亚洲欧洲视频在线| 亚洲国产天堂久久综合| 国产成人综合精品| 欧美激情网站在线观看| 亚洲jizzjizz日本少妇| www.精品av.com| 日韩大陆毛片av| 国产欧美日韩中文字幕| 国产97色在线|日韩| 日韩成人网免费视频| 国产脚交av在线一区二区| 这里只有精品在线播放| 国产一区二区三区中文| 亚洲综合精品伊人久久| 久久夜色精品国产欧美乱| 亚洲www永久成人夜色| 欧美一区三区三区高中清蜜桃| 欧美最猛黑人xxxx黑人猛叫黄| 成人伊人精品色xxxx视频| 国产日韩视频在线观看| 亚洲人成电影在线播放| 亚洲精选中文字幕| 精品国产999| 国产色综合天天综合网| 中国日韩欧美久久久久久久久| 国产精品久久久久77777| 国产精品一区久久久| 欧美裸体xxxxx| 国产精品美乳在线观看| 精品女厕一区二区三区| 日本欧美一二三区| 久久夜精品va视频免费观看| 国产一区视频在线播放| 欧美日韩中文字幕综合视频| 国产色婷婷国产综合在线理论片a| 国产欧美在线观看| 精品成人av一区| 九九久久综合网站| 97精品国产aⅴ7777| 日韩美女在线观看一区| 成人免费在线视频网址| 日本精品一区二区三区在线播放视频| 久久久久久国产精品久久| 亚洲成人网在线| 国产综合久久久久| 中文字幕免费精品一区| 亚洲国产高清福利视频| 日韩成人av网| 日韩有码在线电影| 国产成人精彩在线视频九色| 亚洲国产三级网| 91久久久久久久久久久久久| 97久久精品人搡人人玩| 欧日韩不卡在线视频| 久久精品亚洲热| 中文字幕亚洲激情| 欧美日韩国产一区中文午夜| 日本人成精品视频在线| 92国产精品视频| 日韩精品在线视频美女| 久久久精品在线| 国产精品美乳一区二区免费| 中文字幕不卡在线视频极品| 欧美日韩国产123| 日韩欧美在线第一页| 久久久极品av| 欧美成人三级视频网站| 国产视频亚洲视频| 亚洲国产日韩欧美在线动漫| 亚洲激情视频网站| 精品国产欧美成人夜夜嗨| 亚洲人成网站色ww在线| 欧美成人第一页| 亚洲成人精品视频| 中文字幕精品在线视频| 2019中文字幕在线| 国产在线精品一区免费香蕉| 欧美在线观看视频| 欧美国产欧美亚洲国产日韩mv天天看完整| 亚洲一区免费网站| 亚洲成av人片在线观看香蕉| 国产专区欧美专区| 亚洲精品福利在线观看| 国产精品久久av| 精品中文字幕久久久久久| 亚洲毛茸茸少妇高潮呻吟| 国产欧美精品一区二区三区介绍| 成人妇女免费播放久久久| 国产91精品久久久久久久| 国产精品ⅴa在线观看h| 日韩精品极品在线观看播放免费视频| 亚洲国产成人爱av在线播放| 欧美精品久久久久久久免费观看| 中文字幕精品www乱入免费视频| 国产精品久久久久免费a∨大胸| 国产精品你懂得| 456亚洲影院| 亚洲精品视频二区| 91精品国产乱码久久久久久久久| 亚洲人成电影在线播放| 欧美日韩国产综合视频在线观看中文| 一本大道香蕉久在线播放29| 成人免费大片黄在线播放| 国产精品久久久久久久一区探花| 日韩精品极品毛片系列视频| 日韩精品视频免费专区在线播放| 国产精品一二三视频| 最好看的2019的中文字幕视频| 欧美黄色成人网|