5

在问这个问题之前,我已经阅读了文档并广泛搜索了这个网站。

$file = new SplFileObject("/var/www/qacentre/compliance/compliance.csv");
$file->setFlags(SplFileObject::READ_CSV);
foreach ($file as $row) {

}

CSV 行示例;

"ABEL, TAMMY 454454","End of: ABEL, TAMMY 454454",QP544454,28/10/2012 11:41,"0811 unlawfully use, possess","STEPHENS, JEREMY 54544454",LINK OPERATIONS,Located details incorrect,Entity: FORD FALCON Reg #: Colour: White

我已经回显了输出,但它似乎无法识别外壳字符(“)。SetCSVControl尽管我使用的是默认外壳,但我尝试使用它。我还尝试在其中转义外壳字符SetCSVControl(因为我无法控制我正在导出的 CSV 文件)。

例如,当我打印第一列的结果时,应该是 (ABEL, TAMMY 454454) 我正在接收 ("ABEL)。

我读过这可能是我的语言环境设置的问题(en-GB,en-US;q=0.8,en;q=0.6)?

任何帮助都会很棒。

4

1 回答 1

2

你可以使用 SplFileObject::fgetcsv

 public array SplFileObject::fgetcsv ([ string $delimiter = "," [, string $enclosure = "\"" [, string $escape = "\\" ]]] )

它在示例中说;

<?php
$file = new SplFileObject("data.csv");
while (!$file->eof()) {
    var_dump($file->fgetcsv());
}
?>

或者

<?php
$file = new SplFileObject("animals.csv");
$file->setFlags(SplFileObject::READ_CSV);
foreach ($file as $row) {
    list($animal, $class, $legs) = $row;
    printf("A %s is a %s with %d legs\n", $animal, $class, $legs);
}
?>

笔记:

%s 表示字符串,%d 是整数

在您的具体情况下

$file = new SplFileObject("/var/www/qacentre/compliance/compliance.csv");
$file->setFlags(SplFileObject::READ_CSV);
foreach ($file as $row) {
var_dump($row);
}

或者你可以

<?php

    $file = new SplFileObject("/var/www/qacentre/compliance/compliance.csv");
    while (!$file->eof()) {
        var_dump($file->fgetcsv());
    }
?>
于 2015-09-16T09:15:19.697 回答