正则表达式将文本月份更改为数字

时间:2011-09-17 12:49:10

标签: php mysql regex csv import

我有一个巨大的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格式。 感谢

2 个答案:

答案 0 :(得分:1)

使用正则表达式很难实现,并且容易出错。 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存储在数据库中或创建新文件并导入它会更有效。我没有任何基准。

答案 1 :(得分:0)

令人惊讶的是,这似乎可以解决问题:

echo date('Y/m/d', strtotime('15AUG09'));

返回:2009/08/15。

如果您可以设法解析CSV,则会以您想要的格式获取日期。