首页 > 解决方案 > 无法在 PHP 中使用数组中的字符串值

问题描述

我有一个包含两个字符串值的数组,但不能使用其中一个。如果我使用

var_dump($array[0]);

结果是

 array(2) { ["id"]=> string(2) "01" ["name"]=> string(10) "Aquamarine" }

var_dump($array[0]["id"]);

告诉我NULL。

我尝试将“id”更改为其他,尝试使用'而不是“,效果相同,strlen($array [0] [“id”])也返回0。第二个(“name”)有效正好。

更新:使用以下代码初始化数组:

$handle = @fopen("stones.csv", "r");
if ($handle) {
    while (($row = fgetcsv($handle, 4096, ';')) !== false) {
        if (empty($fields)) {
            $fields = $row;
            continue;
        }
        foreach ($row as $k=>$value) {
            $array[$i][$fields[$k]] = $value;
        }
        $i++;
    }
    if (!feof($handle)) {
        echo "Error: unexpected fgets() fail\n";
    }
    fclose($handle);
}
var_dump($array[0]);
var_dump($array[0]["id"]);
var_dump(array_keys($array[0]));

所以转储之间没有修改,最后三行返回这个

array(2) { ["id"]=> string(2) "01" ["name"]=> string(10) "Aquamarine" } NULL array(2) { [0]=> string(5) "id" [1]=> string(4) "name" }

现在我看到“id”键中有一些不可见的字符,那么接下来的问题是如何摆脱它们?

标签: phparrays

解决方案


使用内置的“修剪”功能修剪钥匙。参考: http: //php.net/manual/en/function.trim.php

$handle = @fopen("stones.csv", "r");
if ($handle) {
    while (($row = fgetcsv($handle, 4096, ';')) !== false) {
        if (empty($fields)) {
            $fields = $row;
            continue;
        }
        foreach ($row as $k=>$value) {
            $array[$i][trim($fields[$k])] = $value;
        }
        $i++;
    }
    if (!feof($handle)) {
        echo "Error: unexpected fgets() fail\n";
    }
    fclose($handle);
}
var_dump($array[0]);
var_dump($array[0]["id"]);
var_dump(array_keys($array[0]));

推荐阅读