【问题标题】:php import csv file into databasephp将csv文件导入数据库
【发布时间】:2013-05-27 16:09:52
【问题描述】:

我有一个文件需要导入到我的数据库中,但我喜欢一次导入 10 条记录。

例如我的 .csv 文件中有 100 条记录,因此它第一次运行时将从 0 开始,然后转到 10 并将您的更改为 domain.com/importfile.php/?start=10

这是我使用的代码。

$file = fopen($file, "r");
    while (($data = fgetcsv($file, 8000, ",")) !== FALSE) {
        $county = new County();
        $county->countrycode = $countrycode;
        $county->code = trim($data[0]);
        $county->var_name = $county->mod_write_check( trim($data[1]) );
        $county->name = trim($data[1]);
        $county->statecode = trim($data[2]);
        $save = $county->save();
    }
    fclose($file);

我想知道这是否可以做到。

【问题讨论】:

  • 将 CSV 文件解析为数组。缓存它。在 10 之前插入条目。
  • 如果 csv 文件超过 100000 条记录,它会失败,因为它会超时,这就是我喜欢将文件分成 10 条记录的原因。

标签: php mysql


【解决方案1】:

我建议使用SplFileObject 处理文件。

这是一个介绍基础知识的博客:

http://hakre.wordpress.com/2010/07/25/parsing-csv-files-with-php-spl-style/

SplFileObject 可以轻松查找,但结合limitIterator 你也可以这样做:

$csv = new SplFileObject('data.csv');
$csv->setFlags(SplFileObject::READ_CSV);

foreach(new LimitIterator($csv, 0, 500) as $line){
  #save $line
}

Code snippet source

【讨论】:

  • 我需要从 1 到 10 第一次开始,然后从 11 到 20。这确实从我不会的时候开始,但最后记录他总是一样的。
  • 如果我不添加超过 400mb 的 csv 文件会中断
  • 我如何计算这个 csv 文件中的记录数。
【解决方案2】:

您可以使用 $seek = ftell($file); ftell documentationfseek($file, $seek+1) 您需要在会话中或其他地方携带 $seek 的值

【讨论】:

  • 我喜欢在循环到达 10 时从 0 开始,然后刷新页面,但这次它从 11 开始,我喜欢忽略会话以保留信息。
  • 你可以在你的循环之外有一个变量来计算你添加了多少条记录,并在while循环中有一个条件。 $inserted = 0 ; while(data = fgetcsv($file, 8000, ",")) !== FALSE && $inserted <= 10){ $inserted++ ; } $seek = ftell($file);
猜你喜欢
  • 2017-04-06
  • 2017-01-21
  • 2014-08-18
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2016-12-30
  • 1970-01-01
相关资源
最近更新 更多