我在浏览.txt文件的内容时遇到问题(下面的结构):
01Name 1
02whatever contents
03whatever contents
-------------------
01Name 2
02whatever contents
03whatever contents
如您所见,“分隔符”是“-------------------”。现在,问题是:如何将此文件分解为数组,以便我可以搜索特定名称并显示该块的内容?我试图像这样爆炸:
header("Content-type:text/plain");
$file = fopen("cc/cc.txt", "r");
while (!feof($file)) {
$lot = fgets($file);
$chunk = explode("-------------------",$lot);
print_r($chunk);
}
fclose($file);
结果得到了这个:
Array
(
[0] => 01Name 1
)
Array
(
[0] => 02whatever contents
)
Array
(
[0] => 03whatever contents
)
Array
(
[0] => -------------------
)
Array
(
[0] => 01Name 2
)
Array
(
[0] => 02whatever contents
)
Array
(
[0] => 03whatever contents
)
当我想得到这个结果时:
Array
(
[0] => 01Name 1
[1] => 02whatever contents
[2] => 03whatever contents
)
Array
(
[0] => 01Name 2
[1] => 02whatever contents
[2] => 03whatever contents
)
我搜索了PHP; assigning fgets() output to an array和Read each line of txt file to new array element,没有运气。
有什么想法吗?
答案 0 :(得分:5)
您可以使用以下
$result = array();
$file = explode("-------------------", file_get_contents("cc/cc.txt"));
foreach ( $file as $content ) {
$result[] = array_filter(array_map("trim", explode("\n", $content)));
}
var_dump($result);
输出
array
0 =>
array
0 => string '01Name 1' (length=8)
1 => string '02whatever contents' (length=19)
2 => string '03whatever contents' (length=19)
1 =>
array
1 => string '01Name 2' (length=8)
2 => string '02whatever contents' (length=19)
3 => string '03whatever contents' (length=19)
你可以进一步了解
$result = array();
$file = explode("-------------------", file_get_contents("cc/cc.txt"));
foreach ( $file as $content )
{
foreach(array_filter(array_map("trim",explode("\n", $content))) as $line)
{
list($key,$value) = explode(" ", $line);
$result[$key] = $value ;
}
}
var_dump($result);
输出
array
'01Name' => string '2' (length=1)
'02whatever' => string 'contents' (length=8)
'03whatever' => string 'contents' (length=8)
答案 1 :(得分:0)
首先,您应该使用file()
来逐行读取和拆分文件。这是专门为此目的的内置。
您对"-------------------"
的检查失败,因为您没有考虑尾随换行符(\r\n
等)。 (将FILE_IGNORE_NEW_LINES
函数用file()
作为一个解决方案)。虽然在这里使用正则表达式可能更好:
$lines = file($filename);
foreach ($lines as $line) {
if (preg_match('/^\s*---------+\R*$/', $line)) { ... }
}
这种方式有点多余,但更具弹性。
您也可以使用file_get_contents
阅读整个文件,然后使用preg_split
拆分文本块。
答案 2 :(得分:0)
如果您的文件格式一致,每个数据块有三行,您可以简单地解析它。在这里,我创建了整个文件的二维数组:
<?php
header("Content-type:text/plain");
$file = fopen("cc.txt", "r");
$alldata = array();
$index = 0;
while (!feof($file))
{
$alldata[$index]['name'] = fgets($file);
$alldata[$index]['c1'] = fgets($file);
$alldata[$index]['c2'] = fgets($file);
fgets($file); // throw away delimiter line
$index++;
}
fclose($file);
print_r($alldata);
?>
输出:
Array
(
[0] => Array
(
[name] => 01Name 1
[c1] => 02whatever contents
[c2] => 03whatever contents
)
[1] => Array
(
[name] => 01Name 2
[c1] => 02whatever contents
[c2] => 03whatever contents
)
)
答案 3 :(得分:0)
$c = file_get_contents($file);
$lines = explode("-------------------", $c);
foreach ($lines as $l) {
if (strpos($l, 'keyword') !== false) {
echo $l;
die();
}
}