[英]using PHP HTML SIMPLE DOM PARSER with <pre> tag
我正在使用SIMPLE HTML DOM PARSER PHP。
我要解析的文档的部分来源是
<pre>
LINE 1
LINE 2
LINE 3
</pre>
这些代码定义为$ string和
我写了那些PHP代码
$html = str_get_html($string);
$ret = $html->find('pre',0)->plaintext;
echo $ret;
结果是
1号线2号线3号线
但在网络浏览器中,这些HTML代码正在显示
1号线
2号线
3号线
网络浏览器的显示是我想要的。 如何在PHP中获得相同的结果?
您需要在simple_html_dom.php
文件中将Default Parameter $ stripRN设置为false
例如
$stripRN = false;
更改两个函数file_get_html
和str_get_html
所以这
function file_get_html($url, $use_include_path = false, $context=null, $offset = -1, $maxLen=-1, $lowercase = true, $forceTagsClosed=true, $target_charset = DEFAULT_TARGET_CHARSET, $stripRN=true, $defaultBRText=DEFAULT_BR_TEXT, $defaultSpanText=DEFAULT_SPAN_TEXT)
变成
function file_get_html($url, $use_include_path = false, $context=null, $offset = -1, $maxLen=-1, $lowercase = true, $forceTagsClosed=true, $target_charset = DEFAULT_TARGET_CHARSET, $stripRN=false, $defaultBRText=DEFAULT_BR_TEXT, $defaultSpanText=DEFAULT_SPAN_TEXT)
和这个
function str_get_html($str, $lowercase=true, $forceTagsClosed=true, $target_charset = DEFAULT_TARGET_CHARSET, $stripRN=true, $defaultBRText=DEFAULT_BR_TEXT, $defaultSpanText=DEFAULT_SPAN_TEXT)
变成
function str_get_html($str, $lowercase=true, $forceTagsClosed=true, $target_charset = DEFAULT_TARGET_CHARSET, $stripRN=false, $defaultBRText=DEFAULT_BR_TEXT, $defaultSpanText=DEFAULT_SPAN_TEXT)
您想换行,对吗? 以下应该工作:
<?php
foreach ($ret as $string) {
echo "$string\n";
}
编辑:原始代码的反向作用。
您可以使用以下命令在每一行上回显文本:
在浏览器中输出:
1号线
2号线
3号线
档案内容:
<pre>
LINE 1
LINE 2
LINE 3
</pre>
PHP代码:
<?php
$lines = file('myfile.txt');
foreach ($lines as $line_num => $line) {
echo ($line);
}
?>
原始答案,误解了OP的问题,但仍然有用的代码。
您可以使用以下代码在一行中回显文本。
档案内容:
<pre>
LINE 1
LINE 2
LINE 3
</pre>
在浏览器中输出:LINE 1 LINE 2 LINE 3
PHP代码:
<?php
$lines_of_file = file("myfile.txt");
//Now $lines_of_file have an array item per each line
$file_content = file_get_contents("myfile.txt");
$file_content_separated_by_spaces = explode(" ", $file_content);
echo $file_content;
?>
我无法弄清楚如何使用Simple HTML Dom Parser,但是Zend的Dom Query包成功了。 以下代码用于维护pre
元素内文本的格式:
$dom = new Zend\Dom\Query($html_string);
$results = $dom->execute('pre');
foreach ($results as $result) { // each $result is of type DOMElement
echo $result->ownerDocument->saveXML($result);
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.