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

标签 php mysql regex csv import

我有一个巨大的 CSV 文件(1000 万条记录),格式如下。

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 格式。 谢谢

最佳答案

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

关于php - 正则表达式将文本月份更改为数字,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7454852/

相关文章:

mysql - phpmyadmin 更改默认排序规则

java - 正则表达式优化问题

mysql - 从 MYSQL DB 中搜索电话号码

php - 将 MYSQL CSV 保存到服务器

java - mysql insert with java and php : no error but no insert

php - 如何使用 PHP 将大型 Excel 文件导入 MySql 数据库

mysql - Oracle 在实现检查百万条记录的逻辑时出现查询问题

javascript - 正则表达式量词

php - 需要想法 : Selecting rows in table

php - 我们应该在 PHP 中命名函数吗?