解析文本文件时出现意外行为

时间:2016-05-14 06:25:58

标签: php text-processing

我正在学习PHP,&现在我被卡住了。 我正在脚本中读取.txt文件。文件内容如下:

joe:secret
root:admin

我可以使用file()函数轻松读取文件,该函数返回一个数组。我将数据存储在变量中:

$data = file('location/file.txt');

接下来我使用foreach循环,然后我爆炸每一行,并再次将其内容存储在变量中。然后我对变量进行检查,但这是我得到的行为,我不明白。

foreach ($data as $d) {
  $row = explode(":", $d);

  if ($row[0] == "joe" && $row[1] == "secret") {
    echo "match found ";
  }
}

上面的代码确实给出了预期的输出。这是为什么?如果我这样做,

echo $row[0]; echo $row[1];

然后我收到正确的输出。所以我不明白为什么我的支票失败了?

1 个答案:

答案 0 :(得分:2)

这个很棘手;我不怪你没抓住这个:)

首先,让我们使用php -a交互式shell进行调查:

php > $data = file('test.txt');
php > var_dump($data);
array(3) {
  [0]=>
  string(11) "joe:secret
"
  [1]=>
  string(11) "root:admin
"
  [2]=>
  string(1) "
"
}

查看结束报价是如何单独排列的?那是因为每行末尾的\n都保存在$data的每个数组元素中。因此$row[1] 不等于"secret";它等于"secret\n"。要解决此问题,我们只需要rtrim()

foreach ($data as $line) {
  $line = rtrim($line);
  $row = explode(":", $line);

  if ($row[0] == "joe" && $row[1] == "secret") {
    echo "Match found for joe!";
  }
}

现在,它按预期工作:

php > $data = file('test.txt');
php > foreach ($data as $line) {
php {   $line = rtrim($line);
php {   $row = explode(":", $line);
php {
php {   if ($row[0] == "joe" && $row[1] == "secret") {
php {     echo "Match found for joe!";
php {   }
php { }
Match found for joe!
php >

编辑:我们也可以使用file_get_contents()代替file(),因此我们只是将文件内容作为字符串获取,并将其转换为数组:

$data = file_get_contents('test.txt');
foreach (explode("\n", $data) as $line) {
  $row = explode(":", $line);

  if ($row[0] == "joe" && $row[1] == "secret") {
    echo "Match found for joe!";
  }
}