PHPExcel设置自动列宽

代码方式一 使用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');

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值