代码方式一 使用strlen与iconv
$str_a='aaaaaaaa';
$len_a = strlen(iconv('utf-8','gb2312',$str_a))+2;
$sheet->setCellValue("A1",$str_a);
$sheet->getColumnDimension("A")->setWidth($len_a);
excel打开时单元格宽度应该是按照字符宽度设置,
excel跟随系统是用gbk编码,英文占1字符,汉字占2字符,
开发环境一般都是utf-8,
理论上获取单元格内容字符串的gbk字符长度,就是对应单元格最适应宽度。
实测发现会这样设置单元格会有点紧,
不适合观感不美观,所以在字符串长度上加2个字符长度,效果比较好。
<?php
include "../Classes/PHPExcel.php";
$dir=__DIR__;
$excel=new PHPExcel();
//获取sheet
$sheet=$excel->getActiveSheet();
//设置标题
$sheet->setTitle("demo");
$str_a="aaaaaaaaaaaaa";
$str_b='b';
$len_a = strlen(iconv('utf-8','gb2312',$str_a));
$len_b = strlen(iconv('utf-8','gb2312',$str_b));
//设置内容
$sheet->setCellValue("A1",$str_a)->setCellValue("B1",$str_b);
//设置列宽
$sheet->getColumnDimension("A")->setWidth($len_a);
$sheet->getColumnDimension("B")->setWidth($len_b);
//生成文件
$file=PHPExcel_IOFactory::createWriter($excel,"Excel2007");
//保存文件
$file->save($dir.'aaaaaaa.xlsx');
代码方式二 直接使用strlen
// 先获取字符串的长度
$len = strlen('xxxxx')+2
// 获取第A行,设置宽度
$objPHPExcel->getActiveSheet()->getColumnDimension('A')->setWidth($len);
<?php
include "../Classes/PHPExcel.php";
$dir=__DIR__;
$excel=new PHPExcel();
//获取sheet
$sheet=$excel->getActiveSheet();
//设置标题
$sheet->setTitle("demo");
$str_a="aaaaaaaaaaaaa";
$str_b='b';
$len_a = strlen($str_a)+2;
$len_b = strlen($str_b)+2;
//设置内容
$sheet->setCellValue("A1",$str_a)->setCellValue("B1",$str_b);
//设置列宽
$sheet->getColumnDimension("A")->setWidth($len_a);
$sheet->getColumnDimension("B")->setWidth($len_b);
//生成文件
$file=PHPExcel_IOFactory::createWriter($excel,"Excel2007");
//保存文件
$file->save($dir.'aaaaaaa.xlsx');