PHP导出数据到Excel


<?php date_default_timezone_set('PRC'); $filename="info.xls";//先定义一个excel文件 header("Content-Type: application/vnd.ms-execl"); header("Content-Type: application/vnd.ms-excel; charset=utf-8"); header("Content-Disposition: attachment; filename=$filename"); header("Pragma: no-cache"); header("Expires: 0"); //我们先在excel输出表头,当然这不是必须的 echo iconv("utf-8", "gb2312", "编号")."\t"; echo iconv("utf-8", "gb2312", "姓名")."\t"; echo iconv("utf-8", "gb2312", "年龄")."\t"; echo iconv("utf-8", "gb2312", "性别")."\n";//注意这个要换行 //这里我们定义一个数据库为datebse 数据库用户名:root 密码为:123456 $conn = mysql_connect("localhost","root",""); mysql_select_db("thinkphp"); mysql_query("set names utf8"); //在这里我们定义一个名叫studen的表,她有id,name,age,sex四个字段 $sql="select id,name,age,sex from student"; $result=mysql_query($sql); while($row =mysql_fetch_array($result)){ echo iconv("utf-8", "gb2312", $row['id'])."\t"; echo iconv("utf-8", "gb2312", $row['name'])."\t"; echo iconv("utf-8", "gb2312", $row['age'])."\t"; echo iconv("utf-8", "gb2312", $row['sex'])."\n"; }

 2.用PHPExcel 库导出,需要下载PHPExcel库支持。

<?php
/** PHPExcel */
require_once '../lib/PHPExcel/PHPExcel.php';

// Create new PHPExcel object
$objPHPExcel = new PHPExcel();

// Set properties
$objPHPExcel->getProperties()->setCreator("Maarten Balliauw")
    ->setLastModifiedBy("Maarten Balliauw")
    ->setTitle("Office 2007 XLSX Test Document")
    ->setSubject("Office 2007 XLSX Test Document")
    ->setDescription("Test document for Office 2007 XLSX, generated using PHP classes.")
    ->setKeywords("office 2007 openxml php")
    ->setCategory("Test result file");
$objPHPExcel->getActiveSheet()->mergeCells('A1:N1');
$objPHPExcel->getActiveSheet()->getStyle('A1')->getAlignment()->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_CENTER);
//$objPHPExcel->getActiveSheet()->getStyle('A2')->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_CENTER);
//$objPHPExcel->getActiveSheet()->getColumnDimension('A')->setWidth();
$objPHPExcel->getActiveSheet()->getColumnDimension('E')->setWidth(20);
$objPHPExcel->getActiveSheet()->getColumnDimension('C')->setWidth(10);
$objPHPExcel->getActiveSheet()->getColumnDimension('D')->setWidth(15);
$objPHPExcel->getActiveSheet()->getColumnDimension('F')->setWidth(18);
$objPHPExcel->getActiveSheet()->getColumnDimension('M')->setWidth(10);
$objPHPExcel->getActiveSheet()->getColumnDimension('N')->setWidth(20);
$objPHPExcel->getActiveSheet()->getColumnDimension('G')->setWidth(20);
$objPHPExcel->getActiveSheet()->getColumnDimension('I')->setWidth(20);
$objPHPExcel->getActiveSheet()->getColumnDimension('K')->setWidth(21);
$objPHPExcel->getActiveSheet()->getColumnDimension('L')->setWidth(15);

$objPHPExcel->setActiveSheetIndex(0)
    ->setCellValue('A1', '中奖信息表')
    ->setCellValue('A2', '姓名')
    ->setCellValue('B2', '性别')
    ->setCellValue('C2', '奖项')
    ->setCellValue('D2', '活动名称')
    ->setCellValue('E2', '中奖时间')
    ->setCellValue('F2', '媒体人/非媒体人')
    ->setCellValue('G2', '所属媒体')
    ->setCellValue('H2', '职位')
    ->setCellValue('I2', '电话号码')
    ->setCellValue('J2', '电子邮箱')
    ->setCellValue('K2', '身份证号')
    ->setCellValue('L2', '生日')
    ->setCellValue('M2', '总积分')
    ->setCellValue('N2', '绑定时间');

//数据库连接
$db = mysql_connect("localhost", "root", "");
mysql_select_db("df_xtl",$db);  //选择数据库,这里为"ywcl"。
mysql_query("SET NAMES UTF8"); //设定编码方式为UTF8

$sDate = '20101010';
$lDate = '20151010';

$sql="SELECT a.inter_time,a.prize,b.birthday,b.email,b.identity_card,b.media_name,b.position,b.reg_time,b.reporter_name,b.sex,b.sum_score,b.telphone,b.group_info,c.inter_name FROM `interaction` a,media b,interact_menu c
WHERE a.openid = b.openid and a.inter_time>= '".$sDate."' and a.inter_time <= '".$lDate."' and a.inter_name=c.id";
//echo $sql;
//$sql ="select * from media";
$result=mysql_query($sql);
$num=mysql_num_rows($result);
if ($num>0)
{
    $count=2;
    while($data=mysql_fetch_array($result))
    {
        $count+=1;
        $l1="A"."$count";
        $l2="B"."$count";
        $l3="C"."$count";
        $l4="D"."$count";
        $l5="E"."$count";
        $l6="F"."$count";
        $l7="G"."$count";
        $l8="H"."$count";
        $l9="I"."$count";
        $l10="J"."$count";
        $l11="K"."$count";
        $l12="L"."$count";
        $l13="M"."$count";
        $l14="N"."$count";
        if($data['sex'] == 0){
            $data['sex'] = '女';
        }else{
            $data['sex'] = '男';
        }
        if($data['group_info'] == 'meiti'){
            $data['group_info'] ='媒体人';
        }else{
            $data['group_info'] ='非媒体人';
        }
        if($data['prize'] ==0){
            $data['prize'] ='未中奖';
        }else if($data['prize'] ==1){
            $data['prize'] ='一等奖';
        }else if($data['prize'] ==2){
            $data['prize'] ='二等奖';
        }else if($data['prize'] ==3){
            $data['prize'] ='三等奖';
        }

            $objPHPExcel->setActiveSheetIndex(0)
                ->setCellValue($l1, $data['reporter_name'])
                ->setCellValue($l2, $data['sex'])
                ->setCellValue($l3, $data['prize'])
                ->setCellValue($l4, $data['inter_name'])
                ->setCellValue($l5, $data['inter_time'])
                ->setCellValue($l6, $data['group_info'])
                ->setCellValue($l7, $data['media_name'])
                ->setCellValue($l8, $data['position'])
                ->setCellValue($l9, $data['telphone'])
                ->setCellValue($l10, $data['email'])
                ->setCellValue($l11, $data['identity_card'])
                ->setCellValue($l12, $data['birthday'])
                ->setCellValue($l13, $data['sum_score'])
                ->setCellValue($l14, $data['reg_time']);
    }
}

// Rename sheet
$objPHPExcel->getActiveSheet()->setTitle('通讯录');


// Set active sheet index to the first sheet, so Excel opens this as the first sheet
$objPHPExcel->setActiveSheetIndex(0);


// Redirect output to a client’s web browser (Excel5)
header('Content-Type: application/vnd.ms-excel');
header('Content-Disposition: attachment;filename="通讯录.xls"');
header('Cache-Control: max-age=0');

$objWriter = PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel5');
$objWriter->save('php://output');
exit;
?>

  

posted @ 2014-10-17 14:35  Crawford  阅读(402)  评论(0编辑  收藏  举报