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

首頁 > 編程 > regex > 正文

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

2020-01-20 22:17:10
字體:
來源:轉載
供稿:網友
最近,我抽空改成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
后面不一定接的就是lang="php"這樣的屬性啊,有可能是download,也有可能是linenum="on/off"啊,所以,我們的正則還需要改。
CFC4N把正則改為
<coolcode.*?lang="[a-z]+".*?>
截圖如下

細心的朋友可能看出來圖中匹配的紅色框內多出了
<coolcode
,意思也就是說,前面的

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

<coolcode.*?lang="[a-z]+".*?>
果然,匹配正常了。結果見截圖。

到這里,問題似乎解決了,可是,當初糊涂的我,把coolcode的兩種開頭標識都用了,那就是

<coolcode
和[coolcode,那么,看官您認為這個正則該如何改寫呢?
沒錯,無非就是開頭,結尾的標識考慮兩種情況<和[,那么正則就好改了。(別忘了排除規則里的符號哦)
[</[]coolcode[^<>/[/]]*?lang="[a-z]+"[^<>/[/]]*?[>/]]
嗯,好,我們來看下效果:

很好很完美。
下面,就可以去執行了。
可是,我遇到一個很意外的事情。居然發現老的代碼里包含這樣的格式
[coolcode linenum=/"off/" lang=/"cpp/"]<coolcode download=/"/" lang=/"cpp/" linenum="off">
呃,問題在這里了,只是多了個轉義字符/罷了,那么,改起來,也簡單。也就是允許/出現0次或者一次,而標識0次或者1次的符號為?,那么我們直接在/后面加個?,也就是改成這樣/?就可以了嗎?
顯然,不是。在正則表達式里,/也表示轉義,那么,匹配/的話,也得轉義一下/,則應該為//? 這樣才對。
修改后正則為
[</[]coolcode[^<>/[/]]*?lang=//?"[a-z]+//?"[^<>/[/]]*?[>/]]
匹配結果見下圖:

現在,大功告成了。我們可以進行轉換了。關于轉換,我們可以用兩種方法。

•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="http://1"',$contents);
其中正則的i修飾符標識不區分大小寫。

還有,別忘記了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
国产精品免费久久久久久| 97色在线观看免费视频| 97人人爽人人喊人人模波多| 欧美日韩国产在线| 精品福利在线看| 久久精品亚洲一区| 日韩中文字幕免费看| 日韩精品欧美激情| 亚洲人成绝费网站色www| 51久久精品夜色国产麻豆| 欧美丝袜美女中出在线| 国内免费精品永久在线视频| 91国内免费在线视频| 欧美激情视频网站| 8050国产精品久久久久久| 欧美亚洲另类激情另类| 久久久久久久久久久亚洲| 国产日韩在线视频| 中文字幕亚洲综合| 国产一区香蕉久久| 亚洲第一黄色网| 中文字幕不卡av| 日韩成人av一区| 5566成人精品视频免费| 555www成人网| 亚洲人成电影网站| 欧美激情va永久在线播放| 韩日欧美一区二区| 久久亚洲精品成人| 日韩高清电影好看的电视剧电影| 亚洲精品动漫100p| 最近2019中文字幕大全第二页| 亚洲网址你懂得| 国产精品亚洲综合天堂夜夜| 日韩欧美亚洲国产一区| 欧美日韩国产色| 国产精品日韩在线观看| 久久亚洲精品一区| 热久久免费视频精品| 成人h片在线播放免费网站| 欧美性一区二区三区| 欧美成人网在线| 国产999精品视频| 国产精品第一第二| 日韩免费不卡av| 欧美性猛交xxxxx免费看| 91高潮在线观看| 欧美激情小视频| 这里只有精品在线观看| 裸体女人亚洲精品一区| 日韩欧美国产免费播放| 国产在线观看一区二区三区| 亚洲乱码国产乱码精品精| 在线视频欧美性高潮| 久久久999精品免费| 77777少妇光屁股久久一区| 激情成人中文字幕| 91久久久久久久久久久| 久久人人爽人人爽爽久久| 午夜精品www| 色噜噜狠狠狠综合曰曰曰| 九九视频这里只有精品| 欧美精品免费在线观看| 亚洲欧美日韩天堂一区二区| 久久精品国产清自在天天线| 在线精品国产欧美| 这里只有精品丝袜| 亚洲国产欧美一区二区丝袜黑人| 另类图片亚洲另类| 亚洲精品大尺度| 中文国产成人精品| 九九精品视频在线| 日韩精品在线观看网站| 国产精品一区专区欧美日韩| 国产精品久久久久久久av大片| 精品视频一区在线视频| 国产精品久久久久久影视| 国产成人97精品免费看片| 国产一区二区三区高清在线观看| 亚洲欧美国产一区二区三区| 精品久久久久久久久久ntr影视| 国产成人激情小视频| 色综合天天狠天天透天天伊人| 欧亚精品中文字幕| 伊人男人综合视频网| 亚洲男人第一av网站| 午夜精品久久久久久久99黑人| 在线一区二区日韩| 亚洲天堂av网| 国产91精品在线播放| 97成人在线视频| 国产午夜精品理论片a级探花| 日韩欧美亚洲综合| 欧美日本在线视频中文字字幕| 国产91精品不卡视频| 国产精品高潮粉嫩av| 久久久国产一区二区| 97国产精品视频人人做人人爱| 欧美一级在线亚洲天堂| 日韩精品免费电影| 91久久精品视频| 一区二区三区亚洲| 色综合伊人色综合网| 日韩成人av在线播放| 秋霞成人午夜鲁丝一区二区三区| 久久99精品久久久久久噜噜| 日韩成人中文电影| 欧美激情视频在线观看| 91精品国产成人| 成年人精品视频| 欧美日韩国产精品一区二区三区四区| 久久精品美女视频网站| 欧美理论片在线观看| 亚洲人av在线影院| 91在线观看欧美日韩| 亚洲美女在线看| 精品亚洲一区二区三区在线播放| 色综合久久精品亚洲国产| 国产日韩在线播放| 日韩免费在线看| 日韩久久午夜影院| 日本韩国在线不卡| 中文字幕亚洲专区| 日产日韩在线亚洲欧美| 欧美俄罗斯乱妇| 亚洲va男人天堂| 国产精品久久国产精品99gif| 少妇高潮久久久久久潘金莲| 裸体女人亚洲精品一区| 日韩在线观看视频免费| 国产成人在线一区| 亚洲男人第一av网站| 亚洲人成网在线播放| 日本国产一区二区三区| 久久精品国产视频| 亚洲人精选亚洲人成在线| 九九热最新视频//这里只有精品| 亚洲一区二区久久久久久久| 亚洲欧美中文字幕在线一区| 成人自拍性视频| 国产精品video| 日韩欧美国产免费播放| 午夜精品久久久久久99热软件| 日本高清不卡的在线| 欧美在线视频一区二区| 欧美日韩成人在线播放| 亚洲第一网站男人都懂| 91在线无精精品一区二区| 日韩av最新在线观看| 成人h视频在线观看播放| 91精品国产91久久久久久不卡| 日韩在线观看免费全| 国产精品99久久久久久久久久久久| 日韩免费精品视频| 国产精品成人av性教育| 精品国产户外野外| 日韩一区二区三区国产| 国产精品男人爽免费视频1| 北条麻妃一区二区在线观看| 亚洲娇小xxxx欧美娇小| 午夜免费日韩视频| 日韩大片免费观看视频播放| 亚洲欧美成人网| 国产欧美在线视频|