繁体   English   中英

使用PHP HTML SIMPLE DOM PARSER与 <pre> 标签

[英]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_htmlstr_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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM