我有一个巨大的CSV文件(10M条记录),格式如下。
147804,AC,34,15AUG09,09:00,15AUG09,21:00,YYZ,YVR,PLS
147816,AC,34,26AUG09,09:00,01SEP09,21:00,YYZ,YVR,PLS
我需要将它们导入mysql数据库。如何将所有月份更改为数字月份,最好是yyyy/mm/dd格式。由于
这很难用regex完成,而且容易出错。PHP有内置的CSV支持,这样就安全多了。
<?php
if (($if = fopen("src_file.csv", "r")) !== FALSE) {
if (($of = fopen("dst_file.csv", "w")) !== FALSE) {
while (($cols = fgetcsv($if)) !== FALSE) {
$cols[3] = date('Y/m/d',strtotime($cols[3]));
$cols[5] = date('Y/m/d',strtotime($cols[5]));
fputcsv($of, $cols);
}
fclose($of);
}
fclose($if);
}
?>
我不知道仅仅将$cols
存储在数据库中还是创建一个新文件并导入它会更有效。我没有任何基准。
令人惊讶的是,这似乎奏效了:
echo date('Y/m/d', strtotime('15AUG09'));
return: 2009/08/15.
如果你能解析你的CSV文件,你就能得到你想要的日期格式。