[英]How to trim all leading/trailing <br> code using php
我试图使用PHP删除字符串中的所有前导和尾随<br>
。
这是一个例子
<br><br>
Hello<br>
World<br>
<p>This is a message<br>...</p>
<br><br><br><br>
我想回来
Hello<br>
World<br>
<p>This is a message<br>...</p>
我试着做以下事情
echo trim($str, '<br>');
但它并没有删除它们。 如何删除新的行html代码?
将preg_replace
与开头^
和end $
anchors一起使用:
$string = preg_replace('/^(<br>){0,}|(<br>){0,}$/', '', $string);
或多行:
$string = preg_replace('/^(<br>){0,}|(<br>){0,}$/m', '', $string);
你也可以多次trim()
:
while($string !== ($string = trim($string, '<br>'))){}
这个功能完成了这项工作。 也适用于其他任何事情。
//remove all leading and trailing occurences of needle ($n) from haystack ($h)
function trimAll($h, $n){
if(!$h = trim($h,$n)){
trimAll($h, $n);
}
return $h;
}
我编写了这个函数,它可以更好地完成工作,因为它为我提供了更多的灵活性,可以删除要删除的字符,默认情况下,此函数将首先按顺序删除前导/尾随字符:
function trimString($str, $myList = array("\t","\n", "<br>","<br />", "\t","\n") ){
if( ! is_array($myList) ){
$charsToTrim[] = $chr;
} else {
$charsToTrim = $myList;
}
foreach($charsToTrim as $chr){
$len = strlen($chr);
$nlen = $len * -1;
while( substr($str, 0, $len) == $chr){
$str = trim(substr($str, $len));
}
while( substr($str, $nlen) == $chr){
$str = trim(substr($str, 0, $nlen));
}
}
return $str;
}
使用
// default use case
echo trimString($message);
要么
//remove only one string
echo trimString($message, '<br>'); // remove only the leading training '<br>'
要么
//remove more than 1 string in order
echo trimString($message, array('<br>'<br />') );
我希望这有助于那里的人:)
$p=array(
'<br><br>',
'Hello<br>',
'World<br>',
'<p>This is a message<br>...</p>',
'<br><br><br><br>'
);
function trimdeluxe($str, $sub)
{
$parts=explode($sub, $str);
for ($x=0; $x<2; $x++) {
foreach ($parts as $i=>$v) {
if (!strlen($v)) {
unset($parts[$i]);
} else {
break;
}
}
$parts=array_reverse($parts);
}
return implode($sub,$parts);
}
foreach ($p as $str) {
print $str . ' -> ' . trimdeluxe($str, '<br>') . "\n";
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.