php读取csv问题

WBOY
リリース: 2016-06-06 20:48:12
オリジナル
1188 人が閲覧しました

php读取csv问题 测试环境php5.4,服务器环境php5.2,服务器上无法读取,测试环境正常。 请问一下,我php读取csv文件的时候,带双引号的字段能读取出来,不带双引号的字段读取不出来,这个问题是怎么回事呢?

在有的机器上面是正常的,在有的机器上面是不能读取出来。

csv是excel生成的,查看了excel的帮助文件,当单元格里面有逗号的时候,会自动添加双引号。 `
if (isset($_POST['import'])) {
$file = $_FILES['csv_goods'];
$file_type = substr(strstr($file['name'], '.'), 1);

<code>// 检查文件格式
if ($file_type != 'csv') {
    echo '文件格式不对,请重新上传!';
    exit;
}

$handle = fopen($file['tmp_name'], "rb");
require_once('./function.php');
$row = '';

while ($data = fgetcsv($handle, 1000, ',')) {
    unset($setsqlarr);
    unset($rw);
    unset($re);
    $row++;
    if ($row == 1)
        continue;
    $num = count($data);
    for ($i = 0; $i </code>
ログイン後にコピー
ログイン後にコピー

回复内容:

php读取csv问题 测试环境php5.4,服务器环境php5.2,服务器上无法读取,测试环境正常。 请问一下,我php读取csv文件的时候,带双引号的字段能读取出来,不带双引号的字段读取不出来,这个问题是怎么回事呢?

在有的机器上面是正常的,在有的机器上面是不能读取出来。

csv是excel生成的,查看了excel的帮助文件,当单元格里面有逗号的时候,会自动添加双引号。 `
if (isset($_POST['import'])) {
$file = $_FILES['csv_goods'];
$file_type = substr(strstr($file['name'], '.'), 1);

<code>// 检查文件格式
if ($file_type != 'csv') {
    echo '文件格式不对,请重新上传!';
    exit;
}

$handle = fopen($file['tmp_name'], "rb");
require_once('./function.php');
$row = '';

while ($data = fgetcsv($handle, 1000, ',')) {
    unset($setsqlarr);
    unset($rw);
    unset($re);
    $row++;
    if ($row == 1)
        continue;
    $num = count($data);
    for ($i = 0; $i </code>
ログイン後にコピー
ログイン後にコピー

http://www.php.net/manual/en/function.fgetcsv.php

文档里写的很清楚,第二个参数要求比你csv文件里最长行的长度要大,你要是不确定最长的行有多长就干脆不用加第二个参数,另外第三个参数默认值就是,,完全没有必要多此一举。

while ($data = fgetcsv($handle, 1000, ',')) {
建议改成
while ($data = fgetcsv($handle)) {

最后:文档里的示例代码只是示例,不要照抄!

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート
私たちについて 免責事項 Sitemap
PHP中国語ウェブサイト:福祉オンライン PHP トレーニング,PHP 学習者の迅速な成長を支援します!