[原创]php批量替换Excel文件内容
手里有一大批Excel文件,不过里面有几行数据是不对的,需要替换,本来想着用VC写个程序来替换,但太麻烦也为了考验一下PHP的强大之处,就改用了PHP编写,首先想到的是用PHPExcel,不过查了查官方的guide,PHPExcel是不支持替换的,只支持读和写,也就是说在
手里有一大批Excel文件,不过里面有几行数据是不对的,需要替换,本来想着用VC写个程序来替换,但太麻烦也为了考验一下PHP的强大之处,就改用了PHP编写,首先想到的是用PHPExcel,不过查了查官方的guide,PHPExcel是不支持替换的,只支持读和写,也就是说在遍历的过程中需要把每个单元格所有的样式全部获取出来然后再往新的excel里面写,这无疑是绕了一个大圈子,而且有合并单元格的会更麻烦。所以就查了查MSDN,决定用COM接口来实现。废话不说,把关键代码贴出来:
$excelPath = "e:\\excel"; $total = $success = $jump = 0; $objExcel = new COM("excel.application") or die("不能打开Excel应用程序"); $handle = opendir($excelPath); //打开当前目录 readdir($handle); //排除"." readdir($handle); //排除 ".." //循环读取文件 while ($file = readdir($handle)) { $total++; //生成源文件名 $fileName = $excelPath . DIRECTORY_SEPARATOR .$file; $pathinfo = pathinfo($fileName); if(strtolower($pathinfo['extension']) != 'xls'){ echo "已跳过:".$file.",文件格式不对"; $jump++; continue; } echo "正在替换文件:".$file."\n"; if(file_exists($fileName)){ if(!$objExcel->Application->WorkBooks->Open($fileName)){ echo $file."打开失败,跳过!"; $jump++; continue; } } else{ echo $fileName."文件不存在\n"; $jump++; continue; } $totalRow = $objExcel->ActiveSheet->UsedRange->Rows->Count; for($i=1;$i<=$totalRow;$i++){ $keyword = trim($objExcel->Worksheets(1)->Range("A".$i)->Value);//获取到值 if(in_array($keyword,$replaceIn)){//判断后在这里进行替换 $objExcel->Worksheets(1)->Range("B".$i)->Value = $replaceRule[$keyword]; $objExcel->Worksheets(1)->Range("B".$i)->Font->Name = "黑体"; $objExcel->Worksheets(1)->Range("B".$i)->Font->Size = 12; } } if(!$objExcel->ActiveWorkBook->Saved) { $objExcel->ActiveWorkBook->save(); echo $file."保存成功!\n"; $success++; } //关闭工作簿 $objExcel->Quit(); } echo "\n全部替换完成!共{$total}个,成功{$success}个,跳过{$jump}个!\n"; //清空对象 $objExcel = null; exit;
需要注意的是,尽量把这个程序放在命令行下跑,别放在IIS或APACHE下面,因为是调用的系统组件COM,所以可能会出现各种奇葩的错误,这些错误的原因都是因为权限不足引起的,所以直接用管理员身份运行命令行,在命令行下跑就能把权限问题排除在外!
原文地址:[原创]php批量替换Excel文件内容, 感谢原作者分享。

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

热门话题

PHP 8.4 带来了多项新功能、安全性改进和性能改进,同时弃用和删除了大量功能。 本指南介绍了如何在 Ubuntu、Debian 或其衍生版本上安装 PHP 8.4 或升级到 PHP 8.4

CakePHP 是 PHP 的开源框架。它的目的是使应用程序的开发、部署和维护变得更加容易。 CakePHP 基于类似 MVC 的架构,功能强大且易于掌握。模型、视图和控制器 gu

Visual Studio Code,也称为 VS Code,是一个免费的源代码编辑器 - 或集成开发环境 (IDE) - 可用于所有主要操作系统。 VS Code 拥有针对多种编程语言的大量扩展,可以轻松编写

CakePHP 是一个开源MVC 框架。它使开发、部署和维护应用程序变得更加容易。 CakePHP 有许多库可以减少大多数常见任务的过载。

本教程演示了如何使用PHP有效地处理XML文档。 XML(可扩展的标记语言)是一种用于人类可读性和机器解析的多功能文本标记语言。它通常用于数据存储
