2017-03-08 93 views
0

我的脚本从我的收件箱中抓取一个带有制表符分隔数据的文本文件,并且应该将其导入到我的数据库中。问题是数据可能包含特殊字符,例如,&;,这些字符会以分隔符的形式出现并中断我的导入。带有分隔标签的PHP CSV导入 - 忽略逗号?

由于我的虚拟主机提供商的服务器配置

我无法使用LOAD DATALOAD DATA LOCAL,因此下面的方法是我迄今为止的唯一途径。

如何硬编码下面的脚本以便仅通过tabs分隔数据并忽略其他所有内容?

// read content of CSV file 
while (($row = fgetcsv($getdata)) !== FALSE) { 

    // skip the top 3 rows (header information) - Line 0, Line 1 and Line 2 
    if ($line <= 2) { 
    $line++; 
    continue; 

    } else { 

    $sql = "INSERT INTO `$dbtable` 
     (`OPERA_CONF`, `CRS`, `HOLIDEX`, `ARRIVAL`, `DEPARTURE`, `NIGHTS`, `ADULTS`, `KIDS`, `TITLE`, `FIRST`, `LAST`, `NATIONALITY`, `ROOM`, `ROOM_TYPE`, `MBR`, `MBR_NO`, `MBR_LVL`, `RATE`, `CURR`, `RATECODE`, `MARKET`, `COMPANY`, `AGENT`, `EMAIL`, `PHONE`, `TIMESTAMP`) 
     VALUES (
     '" . mysqli_real_escape_string($mysqli, $row[0]) . "', 
     '" . mysqli_real_escape_string($mysqli, $row[1]) . "', 
     '" . mysqli_real_escape_string($mysqli, $row[2]) . "', 
     '" . mysqli_real_escape_string($mysqli, $row[3]) . "', 
     '" . mysqli_real_escape_string($mysqli, $row[4]) . "', 
     '" . mysqli_real_escape_string($mysqli, $row[5]) . "', 
     '" . mysqli_real_escape_string($mysqli, $row[6]) . "', 
     '" . mysqli_real_escape_string($mysqli, $row[7]) . "', 
     '" . mysqli_real_escape_string($mysqli, $row[8]) . "', 
     '" . mysqli_real_escape_string($mysqli, $row[9]) . "', 
     '" . mysqli_real_escape_string($mysqli, $row[10]) . "', 
     '" . mysqli_real_escape_string($mysqli, $row[11]) . "', 
     '" . mysqli_real_escape_string($mysqli, $row[12]) . "', 
     '" . mysqli_real_escape_string($mysqli, $row[13]) . "', 
     '" . mysqli_real_escape_string($mysqli, $row[14]) . "', 
     '" . mysqli_real_escape_string($mysqli, $row[15]) . "', 
     '" . mysqli_real_escape_string($mysqli, $row[16]) . "', 
     '" . mysqli_real_escape_string($mysqli, $row[17]) . "', 
     '" . mysqli_real_escape_string($mysqli, $row[18]) . "', 
     '" . mysqli_real_escape_string($mysqli, $row[19]) . "', 
     '" . mysqli_real_escape_string($mysqli, $row[20]) . "', 
     '" . mysqli_real_escape_string($mysqli, $row[21]) . "', 
     '" . mysqli_real_escape_string($mysqli, $row[22]) . "', 
     '" . mysqli_real_escape_string($mysqli, $row[23]) . "', 
     '" . mysqli_real_escape_string($mysqli, $row[24]) . "', 
     '" . mysqli_real_escape_string($mysqli, $local_time) . "' 
    )"; 

    if(!$mysqli->query($sql)) { 
     echo "\n Error while importing row $line.<br>"; 
     $errcount++; 
    } 
    $line++; 
    } 

感谢

+0

用'fget'命令行并用'\ tab'分解 –

+0

那么如果你有这样一个有限的服务器,这个批量插入就肯定会超时。时间切换到合适的主机 – e4c5

+0

@ e4c5主机实际上是非常好的,到目前为止没有任何脚本超时。我每15分钟运行一次该代码并导入最多500行,到目前为止没有问题。 – Armitage2k

回答