首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 网站开发 > PHP >

php读取excel文件,输出的值乱码解决方法

2012-04-14 
php读取excel文件,输出的值乱码?php$handle fopen(./home.csv,r)while($items fgetcsv($handle,

php读取excel文件,输出的值乱码
<?php
$handle = fopen("./home.csv","r");
 while($items = fgetcsv($handle,1000)){
  foreach($items as $k=>$v){
  $v = iconv('gb2312','utf-8',$v); 
  var_dump($v);
  }  
 }

[解决办法]
明白了,你说的是这个问题
这是 php5.3 的一个BUG,php5.2 是正常的

你得换个方法解决了
[解决办法]

PHP code
$fname = $_FILES['MyFile']['tmp_name'];//获取上传的CSV文件    $handle=fopen("$fname","r");//打开文件        //判断导入文件类型是否为csv    //如果为csv继续执行    if($_FILES['MyFile']['type'] !='application/vnd.ms-excel')    {    if($_FILES['MyFile']['type'] != 'text/comma-separated-values')      {        echo "<script>alert('您上传的文件类型不符,请重新上传');window.location='subHotel_import.php';</script>";exit();      }    }              $num = 1;        $total_num = 100;//设置每次添加的数据条数        //删除表中原有数据       $db->query("delete from hotel_activities_2");      //打开导入的csv      //循环添加到表中      while(!feof($handle))        {                                    $content = fgets($handle);            $data =  preg_split("/,/",$content);                      if($data[0] =='')            {                   continue;            }                 $subHotel_id = preg_replace('/[^0-9]/','',$data[0]);            $subHotel_type= (int)preg_replace('/[^0-9]/','',$data[4]);            if($num == $total_num )            {                                $num=1;                   $values .=  " ($subHotel_id,'".$data[1]."','".$data[2]."','".$data[3]."',$subHotel_type),";                   $values = rtrim($values,',');                                $sql ="insert into hotel_activities_2 (hotel_id,start_date,end_date,content,s_type) values " .$values;                                $aaa = $db->query($sql);                                $values ='';            }            else             {                $values .=  " ($subHotel_id,'".$data[1]."','".$data[2]."','".$data[3]."',$subHotel_type),";                $num++;                        }                       }        if(mysql_error!==1){            $values = rtrim($values,',');            $sql ="insert into hotel_activities_2 (hotel_id,start_date,end_date,content,s_type) values " .$values;                 $db->query($sql);                               echo "<script>alert('导入成功!!!');window.location='subHotel_query_file.php';</script>";            }else            {            echo "<script>alert('导入失败!!!');window.location='subHotel_import.php';</script>";            }                                             fclose($handle);
[解决办法]
在 csv 格式标准中:字符串是需要用双引号括起的,但微软的工具软件却偏偏不加这个双引号
在 php5.3 以前的版本中,php 也认同这种做法
但自 php5.3 起,微软摆出了不合作姿态,于是 fgetcsv 也就残废了
[解决办法]
读取excel数据要用到一个插件,直接这样读取肯定是不行的。
下面这个是将ecxcel数据读取到数据库的方法:
7.$handle = fopen (”test.csv”,”r”);
8.$sql=”insert into scores(idcard,names ,num,sex,nation,score) values(’”;
9.while ($data = fgetcsv ($handle, 1000, “,”)) {
10.$num = count ($data);
11.for ($c=0; $c < $num; $c++) {
12.if($c==$num-1){$sql=$sql.$data[$c].”‘)”;break;}
13.$sql=$sql.$data[$c].”‘,’”;
14.}
15.print “< br>”;
16.echo $sql.”< br>”;
17.$db->query($sql);
18.echo “SQL语句执行成功!< br>”;
19.$sql=”insert into scores(idcard,names ,num,sex,nation,score) values(’”;
20.}
21.fclose ($handle);
22.$time_end = getmicrotime();


23.$time = $time_end – $time_start;
24.echo “程序执行时间:”.$time.”秒”;
具体请参考:http://www.phpnewer.com/index.php/Ymgx/detail/id/41

热点排行