国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

Maison php教程 php手冊(cè) php導(dǎo)入csv文件亂碼問(wèn)題怎么解決

php導(dǎo)入csv文件亂碼問(wèn)題怎么解決

Jun 13, 2016 am 09:43 AM
aspnet programmation de logiciels

想寫(xiě)一個(gè)php導(dǎo)入csv文件的方法,都是可以實(shí)現(xiàn)怎么去導(dǎo)入的。
但是我導(dǎo)入時(shí)遇到了兩個(gè)問(wèn)題,一個(gè)是在windows上寫(xiě)代碼的時(shí)候測(cè)試發(fā)生了亂碼問(wèn)題,然后解決了。
第二個(gè)是提交到linux系統(tǒng)上的時(shí)候又發(fā)生了亂碼。我開(kāi)始還不清楚是亂碼的原因,一開(kāi)始我還以為是代碼svn提交發(fā)生的錯(cuò)誤,到最后我在我的一個(gè)群里提問(wèn)了一下,一朋友是做phpcms的,他說(shuō)他遇到從Windows提交到Linux的時(shí)候剛開(kāi)始也總是發(fā)生錯(cuò)誤,后來(lái)排查原因就是亂碼導(dǎo)致成的。下面切入正題看怎么解決兩個(gè)問(wèn)題的吧!

問(wèn)題一解決:

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)題。

問(wèn)題二解決:

php讀取csv文件,在linux上出現(xiàn)中文讀取不到的情況,百度,google后找到解決辦法

就是添加了一行代碼setlocale(LC_ALL, 'zh_CN');對(duì),亮瞎你的眼了吧。就這么簡(jiǎn)單,如果你不知道,可能會(huì)花很多時(shí)間去解決這個(gè)問(wèn)題。
PHP setlocale() 函數(shù)解釋
定義和用法

setlocale() 函數(shù)設(shè)置地區(qū)信息(地域信息)。

地區(qū)信息是針對(duì)一個(gè)地理區(qū)域的語(yǔ)言、貨幣、時(shí)間以及其他信息。該函數(shù)返回當(dāng)前的地區(qū)設(shè)置,若失敗則返回 false。
以下是在資料上收集常用的地區(qū)標(biāo)識(shí):
zh_CN GB2312
en_US.UTF-8 UTF-8
zh_TW BIG5
zh_HK BIG5-HKSCS
zh_TW.EUC-TW EUC-TW
zh_TW.UTF-8 UTF-8
zh_HK.UTF-8 UTF-8
zh_CN.GBK GBK

例如、
utf-8: setlocale(LC_ALL, ‘en_US.UTF-8′);
簡(jiǎn)體:setlocale(LC_ALL, ‘zh_CN');

之所以給大家講 setlocale()這個(gè)函數(shù),是因?yàn)槲覍?dǎo)入csv文件到linux系統(tǒng)的時(shí)候發(fā)生了亂碼,包括用了mb_convert_encoding()和iconv()兩個(gè)函數(shù)都是沒(méi)搞定最后問(wèn)題的。最后就加了這一句setlocale(LC_ALL, ‘zh_CN');加在導(dǎo)入csv文件開(kāi)始的代碼前面就輕松搞定了,然后我又找了一下資料,發(fā)現(xiàn)fgetcsv()函數(shù)對(duì)區(qū)域設(shè)置是敏感的。比如說(shuō) LANG 設(shè)為 en_US.UTF-8 的話,單字節(jié)編碼的文件就會(huì)出現(xiàn)讀取錯(cuò)誤,所以我們需要對(duì)其進(jìn)行區(qū)域性的設(shè)置。特分享給大家。

還嘗試用了以下代碼也沒(méi)能搞定,這些都是生成csv文件的header的設(shè)置??赡茉谖疫@里不起作用,但是在你那里也說(shuō)不定哦。所以我都整理出來(lái),盡可能的幫助遇到導(dǎo)入csv文件亂碼的同行,因?yàn)樵跊](méi)辦法的情況下真的太難處理了。大家可以都試試!總有一個(gè)是屬于你的。
$csvContent="csvzero,csvone,csvtwo,csvthree,csvfour,csvfive";
header("Content-Type: application/vnd.ms-excel; charset=GB2312");
header("Pragma: public");
header("Expires: 0"); www.jbxue.com
header("Cache-Control: must-revalidate, post-check=0, pre-check=0");
header("Content-Type: application/force-download");
header("Content-Type: application/octet-stream");
header("Content-Type: application/download");
header("Content-Disposition: attachment;filename=CSV數(shù)據(jù).csv ");
header("Content-Transfer-Encoding: binary ");
$csvContent = iconv("utf-8","gb2312",$csvContent);
echo $csvContent;
exit;
?>

具體看看php導(dǎo)入csv文件的代碼:

兩個(gè)函數(shù)簡(jiǎn)單介紹一下,

mb_detect_encoding()檢測(cè)到的字符編碼,或者無(wú)法檢測(cè)指定字符串的編碼時(shí)返回FALSE。

fgetcsv() 函數(shù)從文件指針中讀入一行并解析 CSV 字段。與fgets() 類似,不同的是 fgetcsv() 解析讀入的行并找出 CSV 格式的字段,然后返回一個(gè)包含這些字段的數(shù)組。fgetcsv() 出錯(cuò)時(shí)返回 FALSE,包括碰到文件結(jié)束時(shí)。

注釋:從 PHP 4.3.5 起,fgetcsv() 的操作是二進(jìn)制安全的。

注釋:CSV 文件中的空行將被返回為一個(gè)包含有單個(gè) null 字段的數(shù)組,不會(huì)被當(dāng)成錯(cuò)誤。

注釋:該函數(shù)對(duì)區(qū)域設(shè)置是敏感的。比如說(shuō) LANG 設(shè)為 en_US.UTF-8 的話,單字節(jié)編碼的文件就會(huì)出現(xiàn)讀取錯(cuò)誤。

注釋:如果碰到 PHP 在讀取文件時(shí)不能識(shí)別 Macintosh 文件的行結(jié)束符,可以激活 auto_detect_line_endings 運(yùn)行時(shí)配置選項(xiàng)。
setlocale(LC_ALL, 'zh_CN'); //設(shè)置地區(qū)信息(地域信息)
$file = $_FILES['files'];
$file_type = substr(strstr($file['name'],'.'),1);
if ($file_type != 'csv'){
echo "";
exit;
}
$handle = fopen($file['tmp_name'],"r");
$file_encoding = mb_detect_encoding($handle);
if ($file_encoding != 'ASCII'){
echo "";
exit;
} www.jbxue.com
$row = 0;
$str="";
$sy="";
while ($data = fgetcsv($handle,1000,',')){
$row++;
if ($row == 0)
continue;
$num = count($data);
for ($i=0; $i$str = (string)$data[$i].'|';
$str = mb_convert_encoding($str, "UTF-8", "GBK"); //已知源碼為GBK,轉(zhuǎn)換為utf-8
$sy .= $str; //我這里做的比較復(fù)雜,是用'|'將csv文件里面的內(nèi)容用'|'全部拼起來(lái),因?yàn)槲覍?dǎo)入的是商品信息,需要根據(jù)用戶需
//要導(dǎo)入的數(shù)據(jù)去定義哪些數(shù)據(jù)是需要導(dǎo)入的。
}
}
if ($sy) { $sy = rtrim($sy, '|'); }
$arr = explode('|',$sy);
$key = array_slice($arr,0,$num); //這個(gè)數(shù)組就是csv文件里面標(biāo)題,就是商品id,標(biāo)題,賣(mài)點(diǎn)等等的數(shù)據(jù)
$skey = array();
$length = array();
$co = count($arr);
$p = $co/$num; //求出要取出的數(shù)據(jù)的長(zhǎng)度
for($j=0;$j$offset=($j-1)*$num; //偏移量,就像分頁(yè)一樣,我這里根據(jù)偏移量取出的一個(gè)數(shù)組就是一個(gè)商品的信息。
if($j==0){
$length[] = array_slice($arr,0,$num);
}else{
$length[] = array_slice($arr,$num+$offset,$num);//取出有哪些字段和商品
}
}
$arrtitle = array();
$arrfileds = array();
$arrtagname = DB::select('字段標(biāo)識(shí)', '字段名稱')->from('字段表')->fetch_all();
foreach ($arrtagname as $value) {
$arrfileds[$value['fileds_tags']] = $value['fileds_name'];
}
foreach ($fileds as $v)
{
$temarr= explode('-', $v);
if (isset($temarr[0]) && !empty($temarr[0])) {
if (isset($temarr[1]) && !empty($temarr[1])) {
if ($temarr[1] == 'wenben') {
$arrtitle[] = $arrfileds[$temarr[0]].'文本';
}
} else {
if ($temarr[0] != 'pic') { //是取出字段是圖片就給去掉
$arrtitle[] = $arrfileds[$temarr[0]];
}
}
}

}

$skey = array();
$order = array();
$order[] = 'act_tag';
$order[] = 'channel_tag';
$order[] = 'created_time';
$order[] = 'orderby';
$rows ='';
$f = $co/$num;//求出有多少件商品
for($p=0;$p//這里就是根據(jù)自己的需求查出自己需要的數(shù)據(jù),通過(guò)用戶需要的商品字段標(biāo)識(shí)查出表里相對(duì)應(yīng)的英文標(biāo)識(shí)。
$skey[]= DB::select('字段標(biāo)識(shí)')->from('字段表')->where('字段名稱', '=', $arrtitle[$p])->fetch_row();
$rows .= $skey[$p]['字段標(biāo)識(shí)'].'|';
}
if($rows){ $rows = rtrim($rows,'|'); }
if(!empty($rows)){ $exrows = explode('|',$rows); }else{ $exrows = array(); }
$skeys = array_merge($order,$exrows);
$count1 = count($skeys); //字段的個(gè)數(shù)
if(!empty($length)){
for($x=1;$x$orders = array();
$orders[] = $act_tag;
$orders[] = $channel_tag;
$orders[] = time();
$newlen = array_merge($orders,$length[$x]);
if($count1 !== count($newlen)){ //如果商品字段的長(zhǎng)度和商品的長(zhǎng)度不等就證明用戶有哪個(gè)字段沒(méi)錄入
$newrs = array();
echo "";
fclose($handle);
exit();
}else{ //start
$arrimport = array_combine($skeys,$newlen); //如果兩個(gè)數(shù)組是相等的我就合并數(shù)組,并把導(dǎo)入csv里面的日期改為時(shí)間戳存儲(chǔ)到數(shù)據(jù)庫(kù)
if(!empty($arrimport['start_time'])){ $sta = strtotime($arrimport['start_time']); }else{ $sta=(int)0; }
if(!empty($arrimport['end_time'])){ $end = strtotime($arrimport['end_time']); }else{ $end=(int)0; }
$arrtime=array('start_time'=>$sta,'end_time'=>$end);
if(!empty($arrimport['start_time']) && !empty($arrimport['end_time'])){
$newrs=array_merge($arrimport,$arrtime);
}else{
$newrs = array();
echo "";
fclose($handle);
exit();
}
if(count($skeys) == count($newrs)){
DB::insert('商品表', array_values($skeys))
->values(array_values($newrs))
->execute();
}
} //end
}
}
if($row-1==(int)0){
echo "";
}else{
echo "

以上是我工作需要所做的csv導(dǎo)入處理,可能和你的導(dǎo)入方式不同!
簡(jiǎn)單導(dǎo)入:


導(dǎo)入模板



if (isset($_POST['import'])){

$file = $_FILES['csv_goods'];

$file_type = substr(strstr($file['name'],'.'),1);

// 檢查文件格式
if ($file_type != 'csv'){
echo '文件格式不對(duì),請(qǐng)重新上傳!';
exit;
} www.jbxue.com
$handle = fopen($file['tmp_name'],"r");
$file_encoding = mb_detect_encoding($handle);

// 檢查文件編碼
if ($file_encoding != 'ASCII'){
echo '文件編碼錯(cuò)誤,請(qǐng)重新上傳!';
exit;
}

$row = 0;
while ($data = fgetcsv($handle,1000,',')){
//echo "$row"; //可以知道總共有多少行
$row++;
if ($row == 1)
continue;
$num = count($data);
// 這里會(huì)依次輸出每行當(dāng)中每個(gè)單元格的數(shù)據(jù)
for ($i=0; $iecho $data[$i]."
";
// 在這里對(duì)數(shù)據(jù)進(jìn)行處理
}
}

fclose($handle);
}

?>

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefa?on, veuillez contacter admin@php.cn

Outils d'IA chauds

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

Video Face Swap

échangez les visages dans n'importe quelle vidéo sans effort grace à notre outil d'échange de visage AI entièrement gratuit?!

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds

Tutoriel PHP
1502
276
Comment se reconnecter à MySQL dans le programme ASP.NET ? Comment se reconnecter à MySQL dans le programme ASP.NET ? Jun 29, 2023 pm 02:21 PM

Comment se reconnecter à MySQL dans le programme ASP.NET ? Dans le développement ASP.NET, il est très courant d'utiliser la base de données MySQL. Cependant, pour des raisons de réseau ou de serveur de base de données, la connexion à la base de données peut parfois être interrompue ou expirer. Dans ce cas, afin de garantir la stabilité et la fiabilité du programme, nous devons rétablir la connexion après la déconnexion de la connexion. Cet article explique comment reconnecter les connexions MySQL dans les programmes ASP.NET. Pour référencer d'abord les espaces de noms nécessaires, référencez-les en tête du fichier de code

La combinaison de Vue.js et ASP.NET fournit des conseils et des suggestions pour l'optimisation des performances et l'expansion des applications Web. La combinaison de Vue.js et ASP.NET fournit des conseils et des suggestions pour l'optimisation des performances et l'expansion des applications Web. Jul 29, 2023 pm 05:19 PM

La combinaison de Vue.js et ASP.NET fournit des conseils et des suggestions pour l'optimisation des performances et l'expansion des applications Web. Avec le développement rapide des applications Web, l'optimisation des performances est devenue une tache indispensable et importante pour les développeurs. En tant que framework frontal populaire, Vue.js combiné à ASP.NET peut nous aider à obtenir une meilleure optimisation et expansion des performances. Cet article présentera quelques conseils et suggestions, et fournira quelques exemples de code. 1. Réduire les requêtes HTTP Le nombre de requêtes HTTP affecte directement la vitesse de chargement des applications Web. passer

Dix fa?ons dont l'IA générative va changer le développement logiciel Dix fa?ons dont l'IA générative va changer le développement logiciel Mar 11, 2024 pm 12:10 PM

Traducteur | Révisé par Chen Jun | Chonglou Dans les années 1990, lorsque les gens parlaient de programmation logicielle, cela signifiait généralement choisir un éditeur, vérifier le code dans la base de code CVS ou SVN, puis compiler le code dans un fichier exécutable. Les environnements de développement intégrés (IDE) correspondants tels qu'Eclipse et Visual Studio peuvent intégrer la programmation, le développement, la documentation, la construction, les tests, le déploiement et d'autres étapes dans un cycle de vie complet de développement logiciel (SDLC), améliorant ainsi l'efficacité du travail des développeurs. Ces dernières années, les outils populaires de cloud computing et d'automatisation DevSecOps ont amélioré les capacités complètes des développeurs, permettant ainsi à un plus grand nombre d'entreprises de développer, de déployer et de maintenir plus facilement des applications logicielles. Aujourd’hui, l’IA générative est le développement de la prochaine génération

Techniques d'utilisation et d'optimisation du pool de connexions MySQL dans les programmes ASP.NET Techniques d'utilisation et d'optimisation du pool de connexions MySQL dans les programmes ASP.NET Jun 30, 2023 pm 11:54 PM

Comment utiliser et optimiser correctement le pool de connexions MySQL dans les programmes ASP.NET ? Introduction : MySQL est un système de gestion de bases de données largement utilisé qui offre des performances élevées, une fiabilité et une facilité d'utilisation. Dans le développement ASP.NET, l'utilisation d'une base de données MySQL pour le stockage des données est une exigence courante. Afin d'améliorer l'efficacité et les performances des connexions aux bases de données, nous devons utiliser et optimiser correctement le pool de connexions MySQL. Cet article explique comment utiliser et optimiser correctement le pool de connexions MySQL dans les programmes ASP.NET.

La combinaison de Vue.js et ASP.NET permet le développement et le déploiement d'applications au niveau de l'entreprise La combinaison de Vue.js et ASP.NET permet le développement et le déploiement d'applications au niveau de l'entreprise Jul 29, 2023 pm 02:37 PM

La combinaison de Vue.js et d'ASP.NET permet le développement et le déploiement d'applications au niveau de l'entreprise Dans le domaine technologique Internet en développement rapide actuel, le développement et le déploiement d'applications au niveau de l'entreprise sont devenus de plus en plus importants. Vue.js et ASP.NET sont deux technologies largement utilisées dans le développement front-end et back-end. Leur combinaison peut apporter de nombreux avantages au développement et au déploiement d'applications au niveau de l'entreprise. Cet article expliquera comment utiliser Vue.js et ASP.NET pour développer et déployer des applications au niveau de l'entreprise à travers des exemples de code. Tout d'abord, nous devons installer

Comment configurer et utiliser correctement le pool de connexions MySQL dans le programme ASP.NET?? Comment configurer et utiliser correctement le pool de connexions MySQL dans le programme ASP.NET?? Jun 29, 2023 pm 12:56 PM

Comment configurer et utiliser correctement le pool de connexions MySQL dans le programme ASP.NET?? Avec le développement d’Internet et l’augmentation du volume de données, la demande d’accès et de connexions aux bases de données augmente également. Afin d’améliorer les performances et la stabilité de la base de données, le pooling de connexions est devenu une technologie incontournable. Cet article explique principalement comment configurer et utiliser correctement le pool de connexions MySQL dans les programmes ASP.NET pour améliorer l'efficacité et la vitesse de réponse de la base de données. 1. Le concept et la fonction du pooling de connexions Le pooling de connexions est une technologie qui réutilise les connexions de bases de données. Elle est utilisée au début du programme.

Configuration recommandée pour le développement ASP.NET à l'aide de Visual Studio sous Linux Configuration recommandée pour le développement ASP.NET à l'aide de Visual Studio sous Linux Jul 06, 2023 pm 08:45 PM

Présentation de la configuration recommandée pour l'utilisation de Visual Studio pour le développement ASP.NET sous Linux : Avec le développement de logiciels open source et la popularité du système d'exploitation Linux, de plus en plus de développeurs commencent à développer ASP.NET sous Linux. En tant qu'outil de développement puissant, Visual Studio a toujours occupé une position dominante sur la plateforme Windows. Cet article explique comment configurer VisualStudio pour ASP.NE sous Linux.

Utilisation et optimisation des performances des transactions du pool de connexions MySQL dans ASP.NET Utilisation et optimisation des performances des transactions du pool de connexions MySQL dans ASP.NET Jun 30, 2023 pm 12:12 PM

Comment utiliser correctement et optimiser les performances des transactions du pool de connexions MySQL dans les programmes ASP.NET?? Dans les programmes ASP.NET, les transactions de base de données constituent une partie très importante. Les transactions garantissent la cohérence et l'intégrité de la base de données tout en offrant de meilleures performances. Lors de l'utilisation d'une base de données MySQL, il est essentiel d'utiliser un pool de connexions pour gérer les ressources de connexion et optimiser les performances. Tout d’abord, comprenons brièvement le concept de pool de connexions MySQL. Le pool de connexions est un pool tampon d'un groupe de connexions en pré-initialisant un certain nombre de connexions.

See all articles