0

0

php读取excel,以及php打包文件夹为zip文件,

php中文网

php中文网

发布时间:2016-06-13 09:29:34

|

1748人浏览过

|

来源于php中文网

原创

php读取excel,以及php打包文件夹为zip文件,

1.把文件下载到本地,放在在Apache环境下
2.d.xlsx是某游戏的服务器名和玩家列表,本程序只适合此种xlsx文件结构,其他结构请修改index.php源码
3.访问zip.php的功能是把生成的files文件夹打包成files.zip
4.访问index.php即可生成files文件夹,里面0.js---n.js 分别存放各个服务器人名,server_name_list.js存放服务器列表。
5.Classes 存放的是php读取excel的功能模块,具体任务逻辑都在index.php

A.PHP读取excel支持excel2007

demo逻辑代码:其中的(arrayRecursive,JSON方法是json数据处理功能,可兼容汉字)
主要借助了:PHPExcel插件,附件中有Classes文件夹,官网:http://www.codeplex.com/PHPExcel
index.php
php 
/** Error reporting */
error_reporting(0);
header("Content-type: text/html; charset=utf-8"); 
?>




标题



    php 
    /**************************************************************
     *
     *  使用特定function对数组中所有元素做处理
     *  @param  string  &$array     要处理的字符串
     *  @param  string  $function   要执行的函数
     *  @return boolean $apply_to_keys_also     是否也应用到key上
     *  @access public
     *
     *************************************************************/
    function arrayRecursive(&$array, $function, $apply_to_keys_also = false)
    {
        static $recursive_counter = 0;
        if (++$recursive_counter > 1000) {
            die('possible deep recursion attack');
        }
        foreach ($array as $key => $value) {
            if (is_array($value)) {
                arrayRecursive($array[$key], $function, $apply_to_keys_also);
            } else {
                $array[$key] = $function($value);
            }
     
            if ($apply_to_keys_also && is_string($key)) {
                $new_key = $function($key);
                if ($new_key != $key) {
                    $array[$new_key] = $array[$key];
                    unset($array[$key]);
                }
            }
        }
        $recursive_counter--;
    }
     
    /**************************************************************
     *
     *  将数组转换为JSON字符串(兼容中文)
     *  @param  array   $array      要转换的数组
     *  @return string      转换得到的json字符串
     *  @access public
     *
     *************************************************************/
    function JSON($array) {
        arrayRecursive($array, 'urlencode', true);
        $json = json_encode($array);
        return urldecode($json);
    }

    require_once 'Classes\PHPExcel.php';  
    require_once 'Classes\PHPExcel\IOFactory.php';  
    require_once 'Classes\PHPExcel\Reader\Excel2007.php';  
    $uploadfile='d.xlsx';  
      
    $objReader = PHPExcel_IOFactory::createReader('Excel2007');/*Excel5 for 2003 excel2007 for 2007*/ 
    $objPHPExcel = PHPExcel_IOFactory::load($uploadfile);
    $sheet = $objPHPExcel->getSheet(0);  
    $highestRow = $sheet->getHighestRow(); // 取得总行数  
    $highestColumn = $sheet->getHighestColumn(); // 取得总列数  

    /*方法【推荐】*/  
    $objWorksheet = $objPHPExcel->getActiveSheet();          
    $highestRow = $objWorksheet->getHighestRow();   // 取得总行数       
    $highestColumn = $objWorksheet->getHighestColumn();          
    $highestColumnIndex = PHPExcel_Cell::columnIndexFromString($highestColumn);//总列数  
    $list = array();
    for ($row = 1;$row <= $highestRow;$row++)         {  
        $strs=array();  
        //注意highestColumnIndex的列数索引从0开始  
        for ($col = 0;$col < $highestColumnIndex;$col++)            {  
            $strs[$col] =$objWorksheet->getCellByColumnAndRow($col, $row)->getValue();  
        }  
        array_push($list, $strs);  
    }
    //读取完毕 $list
    //处理数据,生成新的结构
    $n = 0;
    $ser = array();
    for($i = 0 ; $i < count($list); $i++ ){
        $ser[$n][0] = $list[$i][0];
         if(!is_array(@$ser[$n][1])){
            $ser[$n][1] = array();
        }
         array_push($ser[$n][1], $list[$i][1]);
        if($i != count($list) -1){
          if($list[$i][0] != $list[$i+1][0]){
                $n++;
            } 
        }
     }
    /*输出文件*/
    $sname = array();
    $f = 'files/';//存放目录
    if (! file_exists ( $f )) {
        mkdir ( $f );
    }
    for($j = 0;$j < count($ser); $j++){
        $file = $f.$j.'.js';
        echo $file."
"; $fp=fopen("$file", "w+"); //打开文件指针,创建文件 if ( !is_writable($file) ){ die("文件:" .$file. "不可写,请检查!"); } if (is_writable($file) == false) { die('我是鸡毛,我不能'); } $data = $ser[$j][1]; array_push($sname, $ser[$j][0]); file_put_contents ($file, JSON($data)); fclose($fp); //关闭指针 } $file = $f.'server_name_list.js'; echo $file."
";; $fp=fopen("$file", "w+"); //打开文件指针,创建文件 if ( !is_writable($file) ){ die("文件:" .$file. "不可写,请检查!"); } if (is_writable($file) == false) { die('我是鸡毛,我不能'); } file_put_contents ($file, JSON($sname)); echo "生成完毕!"; echo '打包生成文件' ?>

b.php打包文件夹为zip文件

zip.php

php 
/** Error reporting */
error_reporting(0);
header("Content-type: text/html; charset=utf-8"); 
?>




标题



php
    function addFileToZip($path,$zip){
    $handler=opendir($path); //打开当前文件夹由$path指定。
    while(($filename=readdir($handler))!==false){
        if($filename != "." && $filename != ".."){//文件夹文件名字为'.'和‘..’,不要对他们进行操作
            if(is_dir($path."/".$filename)){// 如果读取的某个对象是文件夹,则递归
                addFileToZip($path."/".$filename, $zip);
            }else{ //将文件加入zip对象
                $zip->addFile($path."/".$filename);
            }
        }
    }
    @closedir($path);
}


$zip=new ZipArchive();
if($zip->open('files.zip', ZipArchive::OVERWRITE)=== TRUE){
    addFileToZip('files', $zip); //调用方法,对要打包的根目录进行操作,并将ZipArchive的对象传递给方法
    $zip->close(); //关闭处理的zip文件
}
echo '打包完毕!'."
"; echo "下载files.zip" ?>

 

代码下载:php-read-excel

PictoGraphic
PictoGraphic

AI驱动的矢量插图库和插图生成平台

下载

http://files.cnblogs.com/zhidong123/php-read-excel.zip

立即学习PHP免费学习笔记(深入)”;

WPS零基础入门到精通全套教程!
WPS零基础入门到精通全套教程!

全网最新最细最实用WPS零基础入门到精通全套教程!带你真正掌握WPS办公! 内含Excel基础操作、函数设计、数据透视表等

下载

相关标签:

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

相关专题

更多
php源码安装教程大全
php源码安装教程大全

本专题整合了php源码安装教程,阅读专题下面的文章了解更多详细内容。

150

2025.12.31

php网站源码教程大全
php网站源码教程大全

本专题整合了php网站源码相关教程,阅读专题下面的文章了解更多详细内容。

88

2025.12.31

视频文件格式
视频文件格式

本专题整合了视频文件格式相关内容,阅读专题下面的文章了解更多详细内容。

90

2025.12.31

不受国内限制的浏览器大全
不受国内限制的浏览器大全

想找真正自由、无限制的上网体验?本合集精选2025年最开放、隐私强、访问无阻的浏览器App,涵盖Tor、Brave、Via、X浏览器、Mullvad等高自由度工具。支持自定义搜索引擎、广告拦截、隐身模式及全球网站无障碍访问,部分更具备防追踪、去谷歌化、双内核切换等高级功能。无论日常浏览、隐私保护还是突破地域限制,总有一款适合你!

61

2025.12.31

出现404解决方法大全
出现404解决方法大全

本专题整合了404错误解决方法大全,阅读专题下面的文章了解更多详细内容。

493

2025.12.31

html5怎么播放视频
html5怎么播放视频

想让网页流畅播放视频?本合集详解HTML5视频播放核心方法!涵盖<video>标签基础用法、多格式兼容(MP4/WebM/OGV)、自定义播放控件、响应式适配及常见浏览器兼容问题解决方案。无需插件,纯前端实现高清视频嵌入,助你快速打造现代化网页视频体验。

16

2025.12.31

关闭win10系统自动更新教程大全
关闭win10系统自动更新教程大全

本专题整合了关闭win10系统自动更新教程大全,阅读专题下面的文章了解更多详细内容。

12

2025.12.31

阻止电脑自动安装软件教程
阻止电脑自动安装软件教程

本专题整合了阻止电脑自动安装软件教程,阅读专题下面的文章了解更多详细教程。

5

2025.12.31

html5怎么使用
html5怎么使用

想快速上手HTML5开发?本合集为你整理最实用的HTML5使用指南!涵盖HTML5基础语法、主流框架(如Bootstrap、Vue、React)集成方法,以及无需安装、直接在线编辑运行的平台推荐(如CodePen、JSFiddle)。无论你是新手还是进阶开发者,都能轻松掌握HTML5网页制作、响应式布局与交互功能开发,零配置开启高效前端编程之旅!

2

2025.12.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 8.2万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 6.9万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 0.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号