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中文網其他相關文章!

两种去除方法:1、利用preg_replace()执行正则表达式搜索所有大写字母并将其替换为空字符即可,语法“preg_replace('/[A-Z]/','',$str)”。2、利用preg_filter()执行正则表达式搜索所有大写字母并将其替换为空字符即可,语法“preg_filter('/[A-Z]/','',$str)”。

方法:1、用“str_replace(" ","其他字符",$str)”语句,可将nbsp符替换为其他字符;2、用“preg_replace("/(\s|\ \;||\xc2\xa0)/","其他字符",$str)”语句。

随着数据量的不断增大,正则表达式匹配成为了程序中常用的操作之一。而在Go语言中,由于其天然的并行ism,以及与底层系统的交互性和高效性,使得Go语言的正则表达式匹配极具优势。那么如何使用Go语言编写高性能的正则表达式匹配呢?一、了解正则表达式在使用正则表达式前,我们首先需要了解正则表达式,了解其基本语法规则以及常用的匹配字符,使我们能够在编写正则表达式时更加

两种方法:1、用preg_replace(),可执行正则表达式的搜索和替换,只需将字符串中匹配的字符替换为空字符即可,语法“preg_replace(正则, "", $str)”。2、用preg_match_all(),可搜索字符串中所有和正则表达式匹配的结果,会将每次的匹配结果放在一个数组$array中,语法“preg_match_all(正则,$str,$array);”。

php中可用preg_match_all()配合正则表达式过滤字符串,只获取中文字符;语法“preg_match_all("/[\x{4e00}-\x{9fff}]+/u","$str",$arr);”,会将匹配字符存入“$arr”数组中。

在javascript中,可以使用replace()函数配合正则表达式“/[u4e00-u9fa5|,]+/ig”来查找字符串中的所有非汉字字符,并将其替换为其他指定值,语法“字符串对象.replace(/[u4e00-u9fa5|,]+/ig,'指定替换值')”。

Java语言正则表达式的使用方法正则表达式是一种强大的文本处理工具,可以用来匹配和验证文本。在Java语言中,也可以使用正则表达式来实现字符串的匹配和处理。本文将介绍Java语言正则表达式的使用方法,涵盖正则表达式的基础知识,常用的正则表达式语法,以及在Java程序中使用正则表达式的方法。一、基础知识正则表达式是什么?正则表达式是一种文本模式,用来描述一组字

在PHP开发中,正则表达式是非常重要的工具,用于匹配、查找和替换文本中的特定字符串。然而,编写高效的正则表达式并不是一件易事,需要开发者具备一定的技巧和经验。下面是一些可以帮助您编写高效正则表达式的技巧:1.尽可能使用非贪婪匹配默认情况下,正则表达式是贪婪的,即它们将尽可能匹配更多的文本。在某些情况下,可能需要使用非贪婪匹配来避免这种情况。非贪婪匹配使用"


熱AI工具

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

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

VSCode Windows 64位元 下載
微軟推出的免費、功能強大的一款IDE編輯器

SublimeText3 Linux新版
SublimeText3 Linux最新版

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

EditPlus 中文破解版
體積小,語法高亮,不支援程式碼提示功能

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