如何透過php正規去掉註釋
php正規則去掉註解的實作方法:先建立PHP範例檔;然後透過正規表示式「reg_replace("/(\/\*.*\*\/)|(#.*?\n )|(\/\/.*?\n)/s", '', str_replace((...))」實現移除即可。
推薦:《PHP影片教學》
測試程式碼
。a.PHP
<?php<br/>/**<br/> * 加法计算<br/> * 测试<br/> */<br/>// 设定$a的值<br/>$a = 10;<br/>// 设定$b的值<br/>$b = 5;<br/>// 加法<br/>$c = $a + $b;<br/># 输出结果<br/>echo $c;<br/>
檔:test.php
#echo "源码:<br />";<br/>show_source('./a.php');<br/>echo "<hr />去除注释后:<br />";<br/>highlight_string(removeComment(file_get_contents('./a.php')));<br/><br/>/**<br/> * 去除PHP代码注释<br/> * @param string $content 代码内容<br/> * @return string 去除注释之后的内容<br/> */<br/>function removeComment($content){<br/> return preg_replace("/(\/\*.*\*\/)|(#.*?\n)|(\/\/.*?\n)/s", '', str_replace(array("\r\n", "\r"), "\n", $content));<br/>}<br/>
測試輸出
執行test.php,輸出如下:
正規分析
(\/\*.*\*\/) 匹配 /* */<br/>(#.*?\n) 匹配 # 遇到第一个回车后结束<br/>(\/\/.*?\n) 匹配 // 遇到第一个回车后结束<br/>
繼續補充一下:
多行註解
<?php <br/> <br/>$s = '/*aaaa <br/>sss <br/>*/*/'; <br/> <br/>preg_match('@/\*.*?\*/@s', $s, $match); <br/> <br/>var_dump($match);<br/>
運行結果
array(1) {<br/> [0]=><br/> string(15) "/*aaaa <br/>sss <br/>*/"<br/>}<br/>
符合單行註解
<?php <br/>$str = " <br/>a = b; //asdf //saf <br/>b = c; //asdf <br/> "; <br/>$reg = '@\s*//.*$@m'; <br/> <br/>$res = preg_replace($reg,'',$str); <br/> <br/>echo $res;<br/>
輸出
a = b; <br/>b = c;<br/>
再來一個lua版的
local test = "int x; /* xx */ xx*/ int y; /* y */" <br/> <br/>function string.gfind(test, patten) <br/> local i,j = 0,0; <br/> return function() <br/> i,j = string.find(test, patten, j+1) <br/> if(i == nil) then -- end find <br/> return nil <br/> end <br/> return string.sub(test, i, j) <br/> end <br/>end <br/> <br/> <br/>for v in string.gfind(test, "/%*.-%*/") do <br/> print(v) <br/>end<br/>
輸出
/* xx */
/* y */
phpstorm 正規符合刪除註解行(取代註解行為空白行)
使用phpstorm 來寫php 和javascript 程式碼,感覺還是不錯的,用得也很舒服。
遇到了一個需求,有時候在閱讀框架原始碼的時候,想過濾(刪除)掉原始程式碼中的註解行,如果手動逐行刪除顯示不夠科學。
當然想到了強大的正則匹配(regExp regular expression), 透過寫一個正規表示式,來找出所有的註解行,並將其替換成空,即實現了需求。
#1. ctrl F , 輸入正規表示式:(\/\/.*$)|(\/\*(.|\s)*?\*\/)
2. ctrl R, 不輸入:
3. 點選後面的Replace all
但發現,這樣並沒有完全實現我們的需求,只是將註解行替換成了空白行。
所以,下面我們再寫一個正規表示式, 將空白行配對出來,刪掉。
1.ctrl F, 輸入正規表示式: ^\n
2.ctrl R, 不輸入
3.點擊後面的Replace all
但發現,還是並沒有全部刪掉空白行。(還有一些空行沒刪掉)
所以,我們繼續來一個正規匹配刪除。
1.ctrl F, 輸入正規表示式: \s\n
2.ctrl R, 不輸入
3.點選後面的Replace all
#好的,到這裡,所有的空白行全部刪除。開心一下 -:)
其實,這三步驟應該可以合成一步實現的,大家可以想想!
以上是如何透過php正規去掉註釋的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

PHP正規表示式驗證:數位格式偵測在編寫PHP程式時,經常需要對使用者輸入的資料進行驗證,其中一個常見的驗證是檢查資料是否符合指定的數字格式。在PHP中,可以使用正規表示式來實現這種驗證。本文將介紹如何使用PHP正規表示式來驗證數字格式,並提供具體的程式碼範例。首先,讓我們來看看常見的數字格式驗證要求:整數:只包含數字0-9,可以以正負號開頭,不包含小數點。浮點

若要使用正規表示式在Golang中驗證電子郵件地址,請執行下列步驟:使用regexp.MustCompile建立正規表示式模式,以符合有效的電子郵件地址格式。使用MatchString函數檢查字串是否與模式相符。此模式涵蓋了大多數有效的電子郵件地址格式,包括:局部使用者名稱可以包含字母、數字和特殊字元:!.#$%&'*+/=?^_{|}~-`網域至少包含一個字母,後面可以跟字母、數字或連字符頂級域名(TLD)不能超過63個字符長

在Go中,可以使用正規表示式比對時間戳記:編譯正規表示式字串,例如用於匹配ISO8601時間戳記的表達式:^\d{4}-\d{2}-\d{2}T \d{2}:\d{2}:\d{2}(\.\d+)?(Z|[+-][0-9]{2}:[0-9]{2})$ 。使用regexp.MatchString函數檢查字串是否與正規表示式相符。

Go語言作為一門現代化的程式語言,提供了強大的正規表示式和字串處理功能,使得開發者能夠更有效率地處理字串資料。掌握Go語言的正規表示式和字串處理,對於開發者來說是非常重要的。本文將詳細介紹Go語言中正規表示式的基本概念和用法,以及如何使用Go語言處理字串。一、正規表示式正規表示式是用來描述字串模式的工具,能夠方便地實現字串的匹配、尋找和替換等操

PHP正規表示式:精確匹配與排除模糊包含正規表示式是一種強大的文字匹配工具,能夠幫助程式設計師在處理文字時進行高效的搜尋、替換和篩選。在PHP中,正規表示式也被廣泛應用於字串處理和資料匹配。本文將重點介紹在PHP中如何進行精確配對和排除模糊包含的操作,同時結合具體的程式碼範例進行說明。精確匹配精確匹配意味著只匹配符合完全條件的字串,不匹配任何變種或包含額外字

Go中使用正規表示式驗證密碼的方法如下:定義正規表示式模式,符合最低密碼要求:至少8個字符,包含小寫字母、大寫字母、數字和特殊字符。使用regexp套件中的MustCompile函式編譯正規表示式模式。使用MatchString方法測試輸入字串是否與正規表示式模式相符。

PHP是一種廣泛應用的程式語言,特別在Web開發領域中非常流行。在網路開發過程中,經常會遇到需要對使用者輸入的文字進行過濾、驗證等操作,其中字元過濾是一項十分重要的操作。本文將介紹如何使用PHP中的正規表示式來實現中文字元過濾的功能,並給出具體的程式碼範例。首先,我們要先明確一下中文字元的Unicode範圍是從u4e00到u9fa5,也就是所有的漢字都處於這個範圍

正規表示式通配符有"."、"*"、"+"、"?"、"^"、"$"、"[]"、"[^]"、"[a-z]"、"[A-Z] "、"[0-9]"、"\d"、"\D"、"\w"、"\W"、"\s&quo
