2

如何删除之间的换行符<table> .... </table>并在每个之后添加 \n

前任:

<table border="0" cellspacing="0" cellpadding="0" width="450" class="descriptiontable"><tr>
<td width="50%" valign="top">
<span class="displayb">Model Procesor:</span> Intel Celeron<br><span class="displayb">Frecventa procesor (MHz):</span> 2660<br><span class="displayb">Placa Video:</span> Intel Extreme Graphics 2<br><span class="displayb">Retea integrata:</span> 10/100Mbps, RJ-45<br><span class="displayb">Chipset:</span> Intel 845G<br>
</td>
<td width="50%" valign="top">
<span class="displayb">Capacitate RAM (MB):</span> 512<br><span class="displayb">Tip RAM:</span> DDR<br>
</td>
</tr></table>

并成为:

<table border="0" cellspacing="0" cellpadding="0" width="450" class="descriptiontable"><tr><td width="50%" valign="top"><span class="displayb">Model Procesor:</span> Intel Celeron<br><span class="displayb">Frecventa procesor (MHz):</span> 2660<br><span class="displayb">Placa Video:</span> Intel Extreme Graphics 2<br><span class="displayb">Retea integrata:</span> 10/100Mbps, RJ-45<br><span class="displayb">Chipset:</span> Intel 845G<br></td><td width="50%" valign="top"><span class="displayb">Capacitate RAM (MB):</span> 512<br><span class="displayb">Tip RAM:</span> DDR<br></td></tr></table>\n

s。

4

3 回答 3

4

我认为您的意思是您有一个完整的 HTML 文件/字符串,并且只想删除表格内的换行符。

您可能应该使用 DOM 解析器来查找 HTML 的相应部分,但是这个临时的正则表达式解决方案可能对您来说很好:

$str = preg_replace('~[\r\n]+(?=(?:(?!<table).)*</table>)~is', '', $str);
$str = preg_replace('~</table>~i', "$0\n", $str);

如果您想\n仅在它不存在的情况下添加它,您可以将其作为第二个替换:

$str = preg_replace('~</table>(?!\n)~i', "$0\n", $str);

这匹配(系统独立)所有换行符,如果它们后面</table>没有<table介于两者之间的话。当然,这会导致嵌套表和类似事物出现问题。这就是为什么你应该使用 DOM 解析器。

于 2012-11-18T16:57:53.077 回答
2
$string = preg_replace('/\s\s+/', '', $string);

这将删除多个空格和换行符。

最后,您只需在结果中添加“\n”:

$string = preg_replace('/\s\s+/', '', $string) . "\n";

这应该这样做。

于 2012-11-18T16:47:06.360 回答
0

找到方法了,忘记发了

$content = str_replace('</table',"</table>\n",str_replace("\n","",$str));
于 2012-11-23T18:57:56.667 回答