1

在这种情况下,我如何输出不带引号的数组

for($i=1; $i <= date("d"); $i++) { $days[] = $i;    }
echo json_encode($days); // ouput [1,2,3,4,5,6,7,8,9,10]

这个第一个很好,但是第二个

for($i=1;$i <= date("d"); $i++) {
        $Sql = "SELECT COUNT(Stats_Clicks) AS Total FROM tabstats WHERE DAY(Stats_Date) = $i
                AND MONTH(Stats_Date) = $month
                AND YEAR(Stats_Date) = $year 
                ";
        $Query = mysql_query($Sql,$Conn) or die (mysql_error($Conn));
        $Rs = mysql_fetch_array($Query);    

        $clicks[] = $Rs['Total'];
    }
    echo json_encode($clicks);

json 输出返回这个

["1","1","0","0","0","0","0","0","0","0","0"]

我需要这个不带引号的这种格式。

4

3 回答 3

3

你只需要转换为整数。

$clicks[] = (int)$Rs['Total'];
于 2012-05-11T02:38:57.470 回答
1

未经测试:

$clicks[] = (int) $Rs['Total'];
于 2012-05-11T02:38:21.553 回答
1

尝试使用 intval 函数的 array_map

像这样:

echo json_encode(array_map("intval",($Rs['Total'])));

例子:

print_r(json_encode(array_map("intval",array("1","2","3"))));
=> [1,2,3]
于 2012-05-11T02:54:13.313 回答