正则表达式删除html代码中的注释

发布网友 发布时间:2022-04-06 01:06

我来回答

5个回答

懂视网 时间:2022-04-06 05:27

php正则去掉注释的实现方法:首先创建PHP示例文件;然后通过正则表达式“reg_replace("/(/*.**/)|(#.*? )|(//.*? )/s", '', str_replace((...))”实现去除即可。

推荐:《PHP视频教程》

测试代码

文件:a.PHP

<?php
/**
* 加法计算
* 测试
*/
// 设定$a的值
$a = 10;
// 设定$b的值
$b = 5;
// 加法
$c = $a + $b;
# 输出结果
echo $c;

文件:test.php

echo "源码:<br />";
show_source('./a.php');
echo "<hr />去除注释后:<br />";
highlight_string(removeComment(file_get_contents('./a.php')));

/**
* 去除PHP代码注释
* @param string $content 代码内容
* @return string 去除注释之后的内容
*/
function removeComment($content){
return preg_replace("/(/*.**/)|(#.*? )|(//.*? )/s", '', str_replace(array(" ", " "), " ", $content));
}

测试输出

执行test.php,输出如下:

正则分析

(/*.**/) 匹配 /* */
(#.*? ) 匹配 # 遇到第一个回车后结束
(//.*? ) 匹配 // 遇到第一个回车后结束

继续补充一下:

多行注释

<?php 

$s = '/*aaaa
sss
*/*/';

preg_match('@/*.*?*/@s', $s, $match);

var_dump($match);

运行结果

array(1) {
[0]=>
string(15) "/*aaaa
sss
*/"
}

匹配单行注释

<?php 
$str = "
a = b; //asdf //saf
b = c; //asdf
";
$reg = '@s*//.*$@m';

$res = preg_replace($reg,'',$str);

echo $res;

输出

a = b; 
b = c;

再来一个lua版的

local test = "int x; /* xx */ xx*/ int y; /* y */" 

function string.gfind(test, patten)
local i,j = 0,0;
return function()
i,j = string.find(test, patten, j+1)
if(i == nil) then -- end find
return nil
end
return string.sub(test, i, j)
end
end


for v in string.gfind(test, "/%*.-%*/") do
print(v)
end

输出
/* xx */
/* y */

phpstorm 正则匹配删除注释行(替换注释行为空行)

使用phpstorm 来编写php 和javascript 代码,感觉还是不错的,用得也很舒服。

遇到了一个需求,有时候在阅读框架源代码的时候 , 想过滤(删除)掉源代码中的注释行,如果手动逐行删除显示不够科学。

当然想到了强大的正则匹配(regExp regular expression), 通过写一个正则表达式,来查找出所有的注释行,并将其替换成空,即实现了需求。

1. ctrl + F , 输入正则表达式:(//.*$)|(/*(.|s)*?*/)

2. ctrl + R, 不输入:

3. 点击后面的 Replace all

但发现,这样并没有完全实现我们的需求,只是将注释行替换成了空行。

所以,下面我们再写一个正则表达式, 将空行匹配出来,删掉。

1.ctrl + F, 输入正则表达式: ^

2.ctrl + R, 不输入

3.点击后面的 Replace all

但发现,还是并没有全部删掉空行。(还有一些空行没删掉)

所以,我们继续来一个正则匹配删除。

1.ctrl + F, 输入正则表达式: s

2.ctrl + R, 不输入

3.点击后面的 Replace all

好的,到这里,所有的空行全部删除。 开心一下 -:)

其实,这三步应该可以合成一步实现的,大家可以想一想!

热心网友 时间:2022-04-06 02:35

java 不熟悉。

用 javascript 的话这样

<script type="text/javascript">

var sHtml = '<p>如何用正则表达式<!--注释begin-->'
+ '<!--***-->这里还有一些内容'
+ '<!--***end-->'
+ '<!--\n注释end\n-->'
+ '</p>';

sHtml = sHtml.replace(/<!--[\w\W\r\n]*?-->/gmi, '');

alert(sHtml);
</script>

java似乎可以这样:

pattern = Pattern.compile("<!--[\\w\\W\r\\n]*?-->");
matcher = pattern.matcher("你的HTML字符串");
String str = matcher.replaceAll("");;

热心网友 时间:2022-04-06 03:53

strhtml是你所要替换的原来文字。用
String strget = strhtml.replaceAll("<(?!/?p)[^>]+>", "");
就可以了,保留<p></p>标签对,其他的html标签删除

热心网友 时间:2022-04-06 05:28

php正则表达式:
.*
完整的php利用正则表达式删除html标签程序如下:
?php
$str = '<p
12345
123abc"def"
';
echo preg_replace('#
.*
#is','',$str);
?>运行结果:
12345

热心网友 时间:2022-04-06 07:19

JS的写法 参考下
function RegExp(r) {
var result = r.replace(/<!--.*-->/gim,"")
}

声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com