最近,我抽空改成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="\\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程序,留言即可,我抽空寫出來。
您可能感興趣的文章:- mysql正則表達式(regexp和rlike)的搜索功能實例分析
- 老生常談MYSQL模式匹配 REGEXP和like的用法
- MySQL中使用replace、regexp進行正則表達式替換的用法分析
- mysql模糊查詢like與REGEXP的使用詳細介紹
- MySQL中REGEXP正則表達式使用大全
- mysql模糊查詢like和regexp小結
- mysql數據庫replace、regexp的用法
- MySQL使用正則表達式進行查詢操作經典實例總結
- Mysql語法、特殊符號及正則表達式的使用詳解
- MySql中使用正則表達式查詢的方法
- mysql 正則表達式查詢含有非數字和字符的記錄
- 簡述MySQL 正則表達式
- MYSQL使用正則表達式過濾數據
- mysql中如何使用正則表達式查詢
- MySQL正則表達式入門教程
- MySql官方手冊學習筆記2 MySql的模糊查詢和正則表達式
- MySQL 字符串模式匹配 擴展正則表達式模式匹配
- mysql正則表達式 LIKE 通配符
- MySql中正則表達式的使用方法描述
- 在MySQL中用正則表達式替換數據庫中的內容的方法
- Mysql中正則表達式Regexp常見用法