php讀取csv文件,在windows上出現(xiàn)中文讀取不到的情況,本人立馬想到一個(gè)函數(shù)mb_convert_encoding();作如下設(shè)置 $str = mb_convert_encoding($str, "UTF-8", "GBK");然后就可以了。當(dāng)然你也可以用iconv();作如下設(shè)置iconv(‘GBK’,”UTF-8//TRANSLIT//IGNORE”,$str);這兩個(gè)函數(shù)來(lái)解決在windows上面發(fā)生亂碼的問(wèn)題。
創(chuàng)新互聯(lián)專注于桐廬企業(yè)網(wǎng)站建設(shè),成都響應(yīng)式網(wǎng)站建設(shè)公司,商城網(wǎng)站建設(shè)。桐廬網(wǎng)站建設(shè)公司,為桐廬等地區(qū)提供建站服務(wù)。全流程按需定制網(wǎng)站,專業(yè)設(shè)計(jì),全程項(xiàng)目跟蹤,創(chuàng)新互聯(lián)專業(yè)和態(tài)度為您提供的服務(wù)
1. 把現(xiàn)有表中的 email 字段設(shè)為 "唯一" 或者 "主鍵";2. 用SQL語(yǔ)句導(dǎo)入csv文件:LOAD DATA INFILE 'file_name.csv' IGNORE #注意, 這里的IGNORE是關(guān)鍵, 不導(dǎo)入重復(fù)的行
INTO TABLE tbl_name
FIELDS
TERMINATED BY ',' #用逗號(hào)分割字段
OPTIONALLY ENCLOSED BY '"' #根據(jù)csv文件的字符串是否用引號(hào)括起來(lái)設(shè)置
phpmyadmin 導(dǎo)入 csv 的用戶界面如下圖:
以下是相關(guān)的注意事項(xiàng)及說(shuō)明:
1、關(guān)于 CSV 和 CSV using LOAD DATA
這兩種都可以導(dǎo)入CSV格式的文件數(shù)據(jù),區(qū)別在于:當(dāng)文件比較大時(shí)用 CSV 可能 script 會(huì)超時(shí),這時(shí)就得使用 LOAD DATA。
2、列名
列名就是你在導(dǎo)出時(shí)打鉤的“將字段名稱放在首行”,實(shí)際就是用分隔符分開(kāi)的字段名集合,就是填寫(xiě)所有字段名,中間用分隔字段的字符隔開(kāi)。
3、Ignore duplicate rows
這個(gè)選項(xiàng)的作用是忽略相同的行,意為相同的行只導(dǎo)入一行數(shù)據(jù)。4、轉(zhuǎn)義字段的字符是指數(shù)據(jù)里面可能含有特殊字符串,如分隔字段的字符、包裹字段的字符還有SQL保留字符,這些得先轉(zhuǎn)義否則會(huì)出錯(cuò),按默認(rèn)的設(shè)置是沒(méi)什么問(wèn)題的。
你用過(guò)phpmyadmin了嗎,那上面不是有這個(gè)功能嗎,你自己去讀源代碼不就解決了嗎
CSV 文件中的空行將被返回為一個(gè)包含有單個(gè) null 字段的數(shù)組,不會(huì)被當(dāng)成錯(cuò)誤。
思路:
讀取csv文件,每讀取一行數(shù)據(jù),就插入數(shù)據(jù)庫(kù)
示例
文件夾結(jié)構(gòu)
/
file.csv????//csv大文件,這里只模擬三行數(shù)據(jù),不考慮運(yùn)行效率(PS:csv文件格式很簡(jiǎn)單,文件一般較小,解析很快,運(yùn)行效率的瓶頸主要在寫(xiě)入數(shù)據(jù)庫(kù)操作)
index.php????//php文件
file.csv
singi,20
lily,19
daming,23
index.php
/**
*?讀取csv文件,每讀取一行數(shù)據(jù),就插入數(shù)據(jù)庫(kù)
*/
//獲取數(shù)據(jù)庫(kù)實(shí)例
$dsn?=?'mysql:dbname=test;host=127.0.0.1';
$user?=?'root';
$password?=?'';
try?{
$db?=?new?PDO($dsn,?$user,?$password);
}?catch?(PDOException?$e)?{
echo?'Connection?failed:?'?.?$e-getMessage();
}
//讀取file.csv文件
if?(($handle?=?fopen("file.csv",?"r"))?!==?FALSE)?{
while?(($row?=?fgetcsv($handle,?1000,?","))?!==?FALSE)?{
//寫(xiě)入數(shù)據(jù)庫(kù)
$sth?=?$db-prepare('insert?into?test?set?name=:name,age=:age');
$sth-bindParam(':name',$row[0],PDO::PARAM_STR,255);
$sth-bindParam(':age',$row[1],PDO::PARAM_INT);
$sth-execute();
}
fclose($handle);
}
數(shù)據(jù)表
CREATE?TABLE?`test`?(
`id`?INT(10)?UNSIGNED?NOT?NULL?AUTO_INCREMENT,
`name`?VARCHAR(255)?NULL?DEFAULT?''?COLLATE?'utf8mb4_bin',
`age`?INT(10)?NULL?DEFAULT?'0',
PRIMARY?KEY?(`id`)
)
COLLATE='utf8mb4_bin'
ENGINE=InnoDB;
運(yùn)行結(jié)束后,數(shù)據(jù)庫(kù)中會(huì)插入csv中的三行數(shù)據(jù)