php上传excel表格并获取数据

 更新时间:2017年04月27日 09:29:48   作者:Miss|ing  
本篇文章主要介绍了php上传excel表格并获取数据的相关知识。具有很好的参考价值。下面跟着小编一起来看下吧

这个是最近需要做的一个功能,在网上也查看了很多相关的文章,基本上大同小异,在这里整理一下。

一:首先是html部分

<html>
<body>
<form action="upload_file.php" method="post" enctype="multipart/form-data">
<input type="file" name="file" id="file" /> 
<input type="submit" name="submit" value="Submit" />
</form>
</body>
</html>

二:就是去接收和处理上传的文件了。php部分

//文件存放的路径
$save_path = "/upload/"; 

//文件存放的文件夹
$save_files = $this->geturl();

这个是以年月日新建的文件夹,仅供参考。

//先检查当前文件夹是否存在,如不存在,创建文件夹
function geturl()
{
$year = date('Y');
$month= date('m');
$day= date('d');

$str = $year.$month.$day;
if(strtoupper(substr(PHP_OS,0,3))=='WIN'){
$path = getcwd() . "/upload/".$str;
}else{
$path = "/mnt/erp/".$str;
}
if(!file_exists($path))//判断文件夹是否存在
{
mkdir($path);
}

//return $path."/";
return $str."/";
}

//这个是上传文件到需要保存的位置,
if (!@move_uploaded_file($_FILES[$upload_name]["tmp_name"], $save_path.$file_path)) {
$error = "error|上传文件错误.";
exit(0);
}

下面开始获取你上传的excel数据了

//获取上传表格的数据
$file_name = $save_path.$file_path;                    //获取上传文件的地址名称
require_once APPPATH . 'views/IDC/config/PHPExcel.php';       
require_once APPPATH . 'views/IDC/config/PHPExcel/IOFactory.php';
require_once APPPATH . 'views/IDC/config/PHPExcel/Cell.php';

$objReader = PHPExcel_IOFactory::createReader('excel2007'); //建立reader对象

$objPHPExcel = $objReader->load($file_name);
$sheet = $objPHPExcel->getSheet();
$highestRow = $sheet->getHighestDataRow(); // 取得总行数

$highestColumn_num = PHPExcel_Cell::columnIndexFromString($sheet->getHighestDataColumn()); //列数

//$columns = PHPExcel_Cell::getColumn($highestColumn_num);
$columns = array('A','B','C','D','E','F','G');

$arr_result = array();
$dealer_element = array();

for ($j = 2; $j <= $highestRow; $j++) {
for ($k = 0; $k < count($columns); $k++) {
//读取单元格
$value = $objPHPExcel->getActiveSheet()->getCell($columns[$k] . $j)->getValue();//这个就是获取每个单元格的值

$value = trim($value);
if (empty($value)) {
$value = NULL;
}
$dealer_element[$k] = $value;
//这里可以根据要求,做一些数据的验证
}

$arr_result[$j] = $dealer_element;
}
echo json_encode($arr_result);

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持脚本之家

相关文章

  • PHP重定向与伪静态区别

    PHP重定向与伪静态区别

    伪静态是SEO重要的方法,通过重定向来实现,并且可以通过重定向来隐藏网站的技术,过滤异常访问。本课分为两部分,前半部分详细介绍Apache重定向的基础知识,后半部分通过多个实际案例再次加深对重定向的理解,并且会演示各种重定向设置后的实际效果。
    2017-02-02
  • php抓取页面与代码解析 推荐

    php抓取页面与代码解析 推荐

    在做一些天气预报或者RSS订阅的程序时,往往需要抓取非本地文件,一般情况下都是利用php模拟浏览器的访问,通过http请求访问url地址,然后得到html源代码或者xml数据。
    2010-07-07
  • PHP的Yii框架使用中的一些错误解决方法与建议

    PHP的Yii框架使用中的一些错误解决方法与建议

    这篇文章主要介绍了PHP的Yii框架使用中的一些错误解决方法与建议,涵盖开启事务机制和关联表的使用等常用功能方面,需要的朋友可以参考下
    2015-08-08
  • PHP7.0连接DB操作实例分析【基于mysqli】

    PHP7.0连接DB操作实例分析【基于mysqli】

    这篇文章主要介绍了PHP7.0连接DB操作,结合实例形式分析了php7基于mysqli连接与查询数据库相关操作技巧,需要的朋友可以参考下
    2019-09-09
  • PHP自带方法验证邮箱是否存在

    PHP自带方法验证邮箱是否存在

    这篇文章主要为大家详细介绍了PHP自带方法验证邮箱是否存在,以及PHP自带方法验证URL、IP是否合法,感兴趣的小伙伴们可以参考一下
    2016-02-02
  • php实现的二分查找算法示例

    php实现的二分查找算法示例

    这篇文章主要介绍了php实现的二分查找算法,结合具体实例形式分析了php二分查找算法的实现与使用技巧,涉及php数组判断、遍历、计算等相关操作,需要的朋友可以参考下
    2017-06-06
  • php中call_user_func函数使用注意事项

    php中call_user_func函数使用注意事项

    这篇文章主要介绍了php中call_user_func函数使用注意事项,较为详细的讲述了call_user_func函数的用法实例与注意事项,具有一定的参考借鉴价值,需要的朋友可以参考下
    2014-11-11
  • PHP实现批量重命名某个文件夹下所有文件的方法

    PHP实现批量重命名某个文件夹下所有文件的方法

    这篇文章主要介绍了PHP实现批量重命名某个文件夹下所有文件的方法,涉及php针对文件夹下文件的遍历、字符串查找、截取及rename函数重命名文件等相关操作技巧,需要的朋友可以参考下
    2017-09-09
  • 解析mysql left( right ) join使用on与where筛选的差异

    解析mysql left( right ) join使用on与where筛选的差异

    本篇文章是对mysql left( right )join使用on与where筛选的差异进行了详细的分析介绍,需要的朋友参考下
    2013-06-06
  • php数组函数序列之array_flip() 将数组键名与值对调

    php数组函数序列之array_flip() 将数组键名与值对调

    array_flip() 函数将使数组的键名与其相应值调换,即键名变成了值,而值变成了键名
    2011-11-11

最新评论