校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁(yè) > 知識(shí)庫(kù) > coolcode轉(zhuǎn)SyntaxHighlighter與Mysql正則表達(dá)式實(shí)現(xiàn)分析

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

熱門標(biāo)簽:上海銷售電銷機(jī)器人軟件 遼寧秒客來電話機(jī)器人 惠安地圖標(biāo)注 淄博市張店區(qū)地圖標(biāo)注 哈爾濱公司外呼系統(tǒng)代理 浙江營(yíng)銷外呼系統(tǒng)有哪些 山東外呼系統(tǒng)聯(lián)系方式 自己做的電銷機(jī)器人 地圖標(biāo)注店鋪地圖標(biāo)注酒店
最近,我抽空改成SyntaxHighlighter。由于coolcode插件的開頭標(biāo)簽是
coolcode>
或者[coolcode]這樣的,而SyntaxHighlighter是

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

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

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

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

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


看圖,這個(gè)正則可以實(shí)現(xiàn)上述要求了。

但是,問題還沒解決,我們還有一種情況沒考慮,那就是
coolcode
后面不一定接的就是lang="php"這樣的屬性啊,有可能是download,也有可能是linenum="on/off"啊,所以,我們的正則還需要改。
CFC4N把正則改為
coolcode.*?lang="[a-z]+".*?>
截圖如下

細(xì)心的朋友可能看出來圖中匹配的紅色框內(nèi)多出了
coolcode
,意思也就是說,前面的

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

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

到這里,問題似乎解決了,可是,當(dāng)初糊涂的我,把coolcode的兩種開頭標(biāo)識(shí)都用了,那就是

coolcode
和[coolcode,那么,看官您認(rèn)為這個(gè)正則該如何改寫呢?
沒錯(cuò),無非就是開頭,結(jié)尾的標(biāo)識(shí)考慮兩種情況和[,那么正則就好改了。(別忘了排除規(guī)則里的符號(hào)哦)
[\[]coolcode[^>\[\]]*?lang="[a-z]+"[^>\[\]]*?[>\]]
嗯,好,我們來看下效果:

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

現(xiàn)在,大功告成了。我們可以進(jìn)行轉(zhuǎn)換了。關(guān)于轉(zhuǎn)換,我們可以用兩種方法。

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

•PHP讀數(shù)據(jù)庫(kù),替換,再寫入。PHP的preg_replace函數(shù)支持反向引用(preg_replace不支持自定義組名的反向引用),我們只好寫個(gè)查詢語(yǔ)句,查詢包含coolcode標(biāo)識(shí)的文章,然后再替換,當(dāng)然,直接查詢包含coolcode的文章可能太多,我們也可以寫個(gè)MYSQL支持的POSIX正則引擎的表達(dá)式,來匹配使用coolcode標(biāo)簽的文章,再來替換,寫入。以減少文章的操作量。當(dāng)然正則表達(dá)式也會(huì)浪費(fèi)很大的資源。
當(dāng)然,在PHP代碼的preg_replace函數(shù)使用上面的正則,進(jìn)行反向引用時(shí),需要對(duì)正則稍作修改。給lang=""中間的一個(gè)組名。正則修改為
[\[]coolcode[^>\[\]]*?lang=\\?"([a-z]+\\?)"[^>\[\]]*?[>\]]
PHP的替換代碼為
$contents = preg_replace('/[|[]coolcode[^>[\]]*?lang=\\\\?"([^"]+?)\\\\?"[^>[\]]*?[>|\]]/i','[code lang="\\1"',$contents);
其中正則的i修飾符標(biāo)識(shí)不區(qū)分大小寫。

還有,別忘記了coolcode的結(jié)束標(biāo)識(shí)和[/coolcode]要替換成[/code]。
mysql里執(zhí)行兩句sql即可
復(fù)制代碼 代碼如下:

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

總結(jié):
本文牽扯的正則表達(dá)式并無高級(jí)用法,都是平常很簡(jiǎn)單的用法。關(guān)于PCRE引擎正則表達(dá)式的遞歸(迭代),組命名,反向引用,零寬斷言等,CFC4N會(huì)在以后的時(shí)間里,找合適的例子寫出來。當(dāng)然,這些高級(jí)用法,CFC4N在幫朋友寫的正則表達(dá)式里已經(jīng)用到了,大家可以看看,歡迎批評(píng)和指點(diǎn)。
PS:如果需要coolcode轉(zhuǎn)SyntaxHighlighter的完整PHP程序,留言即可,我抽空寫出來。
您可能感興趣的文章:
  • mysql正則表達(dá)式(regexp和rlike)的搜索功能實(shí)例分析
  • 老生常談MYSQL模式匹配 REGEXP和like的用法
  • MySQL中使用replace、regexp進(jìn)行正則表達(dá)式替換的用法分析
  • mysql模糊查詢like與REGEXP的使用詳細(xì)介紹
  • MySQL中REGEXP正則表達(dá)式使用大全
  • mysql模糊查詢like和regexp小結(jié)
  • mysql數(shù)據(jù)庫(kù)replace、regexp的用法
  • MySQL使用正則表達(dá)式進(jìn)行查詢操作經(jīng)典實(shí)例總結(jié)
  • Mysql語(yǔ)法、特殊符號(hào)及正則表達(dá)式的使用詳解
  • MySql中使用正則表達(dá)式查詢的方法
  • mysql 正則表達(dá)式查詢含有非數(shù)字和字符的記錄
  • 簡(jiǎn)述MySQL 正則表達(dá)式
  • MYSQL使用正則表達(dá)式過濾數(shù)據(jù)
  • mysql中如何使用正則表達(dá)式查詢
  • MySQL正則表達(dá)式入門教程
  • MySql官方手冊(cè)學(xué)習(xí)筆記2 MySql的模糊查詢和正則表達(dá)式
  • MySQL 字符串模式匹配 擴(kuò)展正則表達(dá)式模式匹配
  • mysql正則表達(dá)式 LIKE 通配符
  • MySql中正則表達(dá)式的使用方法描述
  • 在MySQL中用正則表達(dá)式替換數(shù)據(jù)庫(kù)中的內(nèi)容的方法
  • Mysql中正則表達(dá)式Regexp常見用法

標(biāo)簽:宣城 重慶 長(zhǎng)沙 泰州 西安 綿陽(yáng) 無錫 銅川

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《coolcode轉(zhuǎn)SyntaxHighlighter與Mysql正則表達(dá)式實(shí)現(xiàn)分析》,本文關(guān)鍵詞  coolcode,轉(zhuǎn),SyntaxHighlighter,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《coolcode轉(zhuǎn)SyntaxHighlighter與Mysql正則表達(dá)式實(shí)現(xiàn)分析》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于coolcode轉(zhuǎn)SyntaxHighlighter與Mysql正則表達(dá)式實(shí)現(xiàn)分析的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    欧美久久一区二区| 日韩女优av电影| 欧美videossexotv100| 亚洲视频每日更新| 欧美亚一区二区| 久久精品国产成人一区二区三区| 日韩一区二区免费在线电影| 青青草原综合久久大伊人精品| 91精品国产麻豆| 国产精一区二区三区| 国产女人18毛片水真多成人如厕| 成人精品国产一区二区4080| 一区二区三区成人在线视频| 欧美丰满嫩嫩电影| 99riav一区二区三区| 亚洲高清免费一级二级三级| 日韩欧美国产一二三区| 99免费精品在线| 国产真实乱子伦精品视频| 亚洲欧洲av在线| 337p日本欧洲亚洲大胆精品 | 久久久久久久久久久久久女国产乱 | 亚洲人妖av一区二区| 成人毛片在线观看| 午夜免费久久看| 色播五月激情综合网| 欧美videossexotv100| 99久久亚洲一区二区三区青草| 亚洲人精品一区| 亚洲精品一区二区三区四区高清| 国产精品自拍网站| 亚洲第一av色| 一级特黄大欧美久久久| 午夜欧美视频在线观看| 国产精品视频第一区| 国产欧美精品在线观看| 日本一区二区三级电影在线观看| 久久精品欧美一区二区三区不卡| 日韩一区二区在线观看视频播放| 日本高清视频一区二区| 91电影在线观看| 欧美日韩免费观看一区二区三区| 91在线精品秘密一区二区| 成人综合婷婷国产精品久久| 一本一道波多野结衣一区二区| 欧洲色大大久久| 日韩欧美123| 国产精品久久久久久久第一福利 | 精品国产网站在线观看| 综合久久久久久| 蜜桃视频一区二区三区| 成人91在线观看| 精品日韩一区二区| 欧美日本在线播放| 午夜不卡av免费| 欧美大片日本大片免费观看| 麻豆91在线播放免费| 精品粉嫩超白一线天av| 午夜精品一区在线观看| 成人h动漫精品| 中文字幕av一区二区三区| 久久99精品视频| 日韩一级黄色大片| 亚洲综合色在线| 一本到不卡精品视频在线观看| 欧美一级黄色大片| 亚洲成人精品影院| 在线观看91视频| 欧美激情一区二区三区蜜桃视频| 视频一区在线视频| 色八戒一区二区三区| 久久精品水蜜桃av综合天堂| 国产一区二区三区在线观看精品| 精品国产乱码久久久久久蜜臀| 午夜精品福利在线| 久久亚洲免费视频| 国内成人免费视频| 国产精品美女www爽爽爽| 成人黄色软件下载| 一区二区三区精品在线| 91久久精品一区二区二区| 亚洲女同女同女同女同女同69| 国产激情视频一区二区三区欧美| 26uuu国产日韩综合| 国产69精品久久久久777| 日本一区二区三区dvd视频在线| 国产精品自在在线| 亚洲欧美在线aaa| 欧美一区二区国产| 99精品国产热久久91蜜凸| 天天综合网天天综合色| 精品99久久久久久| 在线一区二区三区四区| 婷婷开心激情综合| 久久久www成人免费无遮挡大片| av一区二区三区在线| 麻豆极品一区二区三区| 亚洲自拍与偷拍| 亚洲人吸女人奶水| 精品日产卡一卡二卡麻豆| 激情欧美日韩一区二区| 美女视频黄 久久| 秋霞成人午夜伦在线观看| 麻豆精品在线播放| 国产在线看一区| 成人v精品蜜桃久久一区| 99re热这里只有精品免费视频| 精品视频1区2区| 国产suv精品一区二区6| 蜜臀久久99精品久久久久久9 | 91麻豆精品秘密| 成人毛片老司机大片| 成人国产精品免费观看动漫| youjizz国产精品| 欧美日韩久久一区二区| 欧美日韩色一区| 成人免费毛片app| 欧美视频一区二区三区四区| 欧美日韩一区二区三区不卡| 91精品国产日韩91久久久久久| 欧美精品三级在线观看| 欧美成人在线直播| 亚洲日本护士毛茸茸| 亚欧色一区w666天堂| 国产资源精品在线观看| 99久久er热在这里只有精品66| 欧美日韩国产中文| 久久婷婷成人综合色| 亚洲欧美一区二区三区极速播放 | 韩国一区二区三区| 色婷婷av一区二区三区之一色屋| 91精品国产品国语在线不卡| 国产精品情趣视频| 麻豆久久久久久久| 欧美日韩一区在线观看| 国产精品伦理在线| 狠狠色综合色综合网络| 欧美日韩成人一区| 午夜欧美视频在线观看| 91精品1区2区| 亚洲激情图片qvod| 91浏览器在线视频| 一区二区在线观看视频| www.久久精品| 欧美性猛交xxxx乱大交退制版| 久久伊人中文字幕| 国产成人av一区二区三区在线| 欧美日韩在线综合| 一区二区三区四区不卡在线 | 日韩电影免费在线观看网站| 欧美制服丝袜第一页| 亚洲国产你懂的| 欧美另类变人与禽xxxxx| 日韩激情一区二区| 久久久久国产精品免费免费搜索| 成人黄色a**站在线观看| 中文字幕一区二区三区在线观看| 99在线热播精品免费| 亚洲女同一区二区| 日韩免费看的电影| 97精品久久久午夜一区二区三区| 国产欧美一区二区精品性色超碰| 亚洲欧洲日本在线| 欧美日韩久久久| 国内精品免费**视频| 国产色一区二区| 欧美亚洲高清一区二区三区不卡| 亚洲乱码一区二区三区在线观看| 免费在线观看精品| 国产日产精品1区| 欧美日本在线播放| 成人av手机在线观看| 免费高清在线一区| 国产精品每日更新在线播放网址| 538prom精品视频线放| 成人av在线资源网| 成人午夜精品一区二区三区| 日韩经典一区二区| 一区二区三区四区视频精品免费 | 亚洲成av人**亚洲成av**| 久久精品亚洲精品国产欧美| 欧美v国产在线一区二区三区| 欧美理论在线播放| 欧美日韩aaa| 欧美精品aⅴ在线视频| 欧洲亚洲国产日韩| 欧美综合久久久| 欧美片在线播放| 5858s免费视频成人| 精品国产电影一区二区| 久久久不卡网国产精品二区| 久久日韩粉嫩一区二区三区| 久久新电视剧免费观看| 国产精品国产三级国产普通话蜜臀 | 精品一区二区三区久久久| 日韩国产高清影视| 免费成人小视频| 亚洲精品ww久久久久久p站| 五月综合激情日本mⅴ| 韩国毛片一区二区三区|