簡體   English   中英

使用php中的utf-8編碼將CSV文件上傳到MySQL

[英]Upload a CSV file to MySQL with utf-8 encoding in php

我正在嘗試使用以下代碼將csv文件上傳到mySQL:

if(isset($_POST["submit"]))
{


header('Content-Type: text/html; charset=utf-8');


$ftype  = $_FILES['file']['type'];

if($ftype == "application/vnd.ms-excel" || $ftype == "APPLICATION/VND.MS-EXCEL"){ 


$file = $_FILES['file']['tmp_name'];



$handle = fopen("$file", "r");

$c = 0;
while(($filesop = fgetcsv($handle, 1000, ",")) !== false)
{

  htmlspecialchars($filesop, ENT_NOQUOTES, "UTF-8");



$fname = $filesop[0];
$lname = $filesop[1];
$famif = $filesop[2];
$lnmvb = $filesop[3];


$sql = mysql_query("insert into Alfon (Name,phone,Address,House,Identification) values ('$fname','$lname','$famif','$lnmvb','')");
$c = $c + 1;
}
if($sql){
echo "הקובץ הועלה בהצלחה 
$fname
$lname
$famif
$lnmvb
$file
";
} 
else
{
echo "שגיאה! אנא פרמט לסוג הקובץ הנכון.";
}

} else { echo "שגיאה בפורמט הקובץ $ftype";}

}


?>
<!DOCTYPE html>

        <title>ספר טלפונים דיגיטלי</title>
<body>
<form enctype="multipart/form-data" accept-charset="utf-8" method="post" role="form">
<div class="form-group">
<label for="exampleInputFile">File Upload</label>
<input type="file" name="file" id="file" size="150" accept-charset="utf-8">
<p class="help-block">Only Excel/CSV File Import.</p>
</div>
<button type="submit" class="btn btn-default" name="submit" value="submit">Upload</button>
</form>
</body>
</html>

問題在於,除了希伯來語文本變成了問號(?)之外,數據還進入了數據庫,您如何將文本編碼為希伯來語? 如果您回答我的問題並幫助我,我將非常感謝您!

(我想強調一下,英文或數字文本確實可以存儲到有效的數據庫中,只有希伯來語文本出錯了...)

使用LOAD DATA INFILE ,並確保包含CHARACTER SET utf8mb4

也就是說,您可以丟棄所有這些PHP代碼,而用此一個MySQL命令替換它。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM