php导入导出cvs文件格式

1、导入

<?php

header("Content-type: text/html; charset=gb2312");   

$fname = $_FILES[‘myfile‘][‘tmp_name‘]; 

error_reporting(0);// 导入csv格式的文件 

$connect=mysql_connect("localhost","root","***") or die("could not connect to database"); 

mysql_select_db("mydb",$connect) or die (mysql_error()); 

mysql_query("set names ‘gbk‘"); 

if(file_exists($fname)){

    $handle = fopen($fname, ‘r‘); 

    $result = input_csv($handle); //解析csv 

	$len_result = count($result); 

	if($len_result==0){ 

        echo ‘没有任何数据!‘; 

        exit; 

    } 

	for ($i = 1; $i < $len_result; $i++) { //循环获取各字段值,从1开始,不插入第一行表头

        //$name = iconv(‘gb2312‘, ‘utf-8‘, $result[$i][0]); //中文转码 

        //$sex = iconv(‘gb2312‘, ‘utf-8‘, $result[$i][1]); 

		$name  =  $result[$i][0];

		$sex  =   $result[$i][1];

		$age = $result[$i][2]; 

		$data_values .= "(‘$name‘,‘$sex‘,‘$age‘),"; 

    } 

    $data_values = substr($data_values,0,-1); //去掉最后一个逗号 

	fclose($handle); //关闭指针 

	$sql  =	 "insert into student (name,sex,age) values $data_values";

	$query = mysql_query($sql);

	 if($query){ 

        echo ‘导入成功!‘; 

    }else{ 

        echo ‘导入失败!‘; 

    }
}else{

	echo "文件不存在,请重新选择";exit;

}

function input_csv($handle) { 

    $out = array (); 

    $n = 0; 

    while ($data = fgetcsv($handle, 10000)) { 

        $num = count($data); 

        for ($i = 0; $i < $num; $i++) { 

            $out[$n][$i] = $data[$i]; 

        } 

        $n++; 

    } 

    return $out; 

} 

?>

  

2、导出

$result = mysql_query("select * from student order by id asc");
$str = "姓名,性别,年龄\n";
$str = iconv(‘utf-8‘,‘gb2312‘,$str);
while($row=mysql_fetch_array($result))
{
    $name = iconv(‘utf-8‘,‘gb2312‘,$row[‘name‘]); //中文转码
    $sex = iconv(‘utf-8‘,‘gb2312‘,$row[‘sex‘]);
    $str .= $name.",".$sex.",".$row[‘age‘]."\n"; //用引文逗号分开
}
$filename = date(‘Ymd‘).‘.csv‘; //设置文件名
export_csv($filename,$str);

function export_csv($filename,$data)
{
      header("Content-type:text/csv");
      header("Content-Disposition:attachment;filename=".$filename);
      header(‘Cache-Control:must-revalidate,post-check=0,pre-check=0‘);
      header(‘Expires:0‘); header(‘Pragma:public‘);
      echo $data;
}

  

附:数据库sql文件

CREATE TABLE `student` (
  `id` int(11) NOT NULL auto_increment,
  `name` varchar(50) NOT NULL,
  `sex` varchar(10) NOT NULL,
  `age` smallint(3) NOT NULL default ‘0‘,
  PRIMARY KEY  (`id`)
) ENGINE=MyISAM  DEFAULT CHARSET=utf8;

  

时间: 2024-10-11 12:02:59

php导入导出cvs文件格式的相关文章

PL/SQLDeveloper导入导出Oracle数据库方法

前一篇博客介绍了Navicat工具备份Oracle的方法,这篇博客介绍一下使用PL/SQL Developer工具导入导出Oracle数据库的方法. PL/SQL Developer是Oracle数据库用于导入导出数据库的主要工具之一,本文主要介绍利用PL/SQL导入导出Oracle数据库的过程. 1.Oracle数据库导出步骤 1.1 Tools→Export User Objects...选项,导出.sql文件. 说明:此步骤导出的是建表语句(包括存储结构). 1.2 Tools→Expor

Eclipse调试程序及项目的导入导出

Eclipse调试程序 调试概述: ①   调试就是测试程序的方法,主要的目的就是解决程序的逻辑问题,流程是:发现问题.修改问题.正确执行; ②   以前我们可以使用System.out.println()方法来查看我们程序中的问题; ③   现在我们可以使用Eclipse开发工具帮我们进行调试: Eclipse为程序员提供了设置断点的功能来达到单步调试程序的能力; 调试步骤: ①   初步判断程序出错的位置; ②   给指定的程序设置断点(可以设置多个); ③   进入调试视图让程序在断点位置

PHP导入导出excel表格图片(转)

写excel的时候,我用过pear的库,也用过pack压包的头,同样那些利用smarty等作的简单替换xml的也用过,csv的就更不用谈了.呵呵.(COM方式不讲了,这种可读的太多了,我也写过利用wps等进行word等的生成之类的文章 )但是在读的时候,只用过一种,具体是什么忘了,要回去翻代码了.基本上导出的文件分为两种:1:类Excel格式,这个其实不是传统意义上的Excel文件,只是因为Excel的兼容能力强,能够正确打开而已.修改这种文件后再保存,通常会提示你是否要转换成Excel文件.优

使用NPOI导入导出标准Excel

尝试过很多Excel导入导出方法,都不太理想,无意中逛到oschina时,发现了NPOI,无需Office COM组件且不依赖Office,顿时惊为天人,怀着无比激动的心情写下此文. 曾使用过的方法 直接导出html,修改后缀名为.xls,这个方法有点像骗人的把戏,而且不能再导入 使用Jet OLEDB引擎来进行导入导出,完全使用sql语句来进行操作,缺点能控制的东西非常有限,比如格式就难以控制 使用Office COM组件进行导入导出,对环境依赖性太强(如"检索 COM 类工厂-"错

excel数据导入导出数据库

第一种方法: 先把Excel另存为.csv格式文件,如test.csv,再编写一个insert.ctl 用sqlldr进行导入! insert.ctl内容如下: load data          --1.控制文件标识 infile ‘my.csv‘          --2.要输入的数据文件名为my.csv append into table "tbl_test"   --3.向表table_name中追加记录 fields terminated by ‘,‘          

[转]PL/SQLDeveloper导入导出Oracle数据库方法

原文地址:http://www.2cto.com/database/201405/305452.html 1.Oracle数据库导出步骤 1.1 Tools→Export User Objects...选项,导出.sql文件. 说明:此步骤导出的是建表语句(包括存储结构),不包括表中的数据,要导出数据需要用Tools→Export Tables. 1.2 Tools→Export Tables...导出表结构及数据 PL/SQL工具包含三种方式导出Oracle表结构及数据,三种方式分别为:Ora

NPOI实现Excel导入导出

NPOI实现Excel的导入导出,踩坑若干. Cyan是博主[Soar360]自2014年以来开始编写整理的工具组件,用于解决现实工作中常用且与业务逻辑无关的问题. 什么是NPOI? NPOI 是 POI 项目的 .NET 版本.POI是一个开源的Java读写Excel.WORD等微软OLE2组件文档的项目.使用 NPOI 你就可以在没有安装 Office 或者相应环境的机器上对 WORD/EXCEL 文档进行读写.NPOI是构建在POI 3.x版本之上的,它可以在没有安装Office的情况下对

PL/SQL Developer导入导出Oracle数据库方法

前一篇博客介绍了Navicat工具备份Oracle的方法,这篇博客介绍一下使用PL/SQL Developer工具导入导出Oracle数据库的方法. PL/SQL Developer是Oracle数据库用于导入导出数据库的主要工具之一,本文主要介绍利用PL/SQL导入导出Oracle数据库的过程. 1.Oracle数据库导出步骤 1.1 Tools→Export User Objects...选项,导出.sql文件. 说明:此步骤导出的是建表语句(包括存储结构). 1.2 Tools→Expor

oracle 导入导出数据

数据导出: 1 将数据库TEST完全导出,用户名system 密码manager 导出到D:/daochu.dmp中      exp system/manager@TEST file=d:/daochu.dmp full=y (远程:exp jeesite/[email protected]:1521/ORCL file=d:/daochu.dmp owner=(jeesite))2 将数据库中system用户与sys用户的表导出   exp system/manager@TEST file=