全部导出和时间导出

html代码,全程并不需要引用什么插件

<include file="public@header"/>
<link href="__TMPL__/public/assets/css/style.css" rel="stylesheet">
</head>
<body>
<div class="margin-top-20 body_top">
<div class="form-inline">
<input type="submit" name="all" class="btn btn-info quanbu" value="全部导出"/> <input style="margin-left: 15px" type="text" name="data" placeholder="日期范围" class="form-control month" id="test6" autocomplete="off">
<input type="submit" class="btn btn-info shijian" value="导出"/>
</div>
</div> </body>
<script src="__STATIC__/js/admin.js"></script>
<script src="__STATIC__/js/laydate/laydate.js"></script>
<script>
//日期范围
laydate.render({
elem: '#test6'
,range: true
}); $('.quanbu').on('click',function () {
$.ajax({
url: "/systems/Sum/quanbu",
type: "post",
dataType: "json",
// data:{'data':nian},
success: function (back) {
if (back.code == 1) {
document.location.href = (back.data);
} else {
layer.msg("导出csv出错!");
}
},
error: function (e) {
console.log(e)
}
});
}); $('.shijian').on('click',function () {
var data=$('.month').val(); $.ajax({
url: "/systems/Sum/shijian",
type: "post",
dataType: "json",
data:{'data':data},
success: function (back) {
if (back.code == 1) {
document.location.href = (back.data);
} else {
layer.msg("导出csv出错!");
}
},
error: function (e) {
console.log(e)
}
});
})
</script>

php代码

 public function quanbu(){
//全部导出
$req=Db::name('cy_sum')
->alias('a')
->field('s.store_name,b.company_name as bloc_name,d.company_name as dealer_name,a.type,a.garment,a.garment_function,a.clothing,a.clothing_function,a.functional_finishing,a.create_time')
->join('store s','a.sid=s.id')
->join('bloc b','a.bid=b.id')
->join('dealer d','a.did=d.id')
->select()
->toArray(); foreach ($req as $k=>$v){
switch ($req[$k]['type']) {
case 1:
$req[$k]['type'] = '定制';
break;
case 2:
$req[$k]['type'] = '定制团单';
break;
case 3:
$req[$k]['type'] = '样衣';
break;
case 4:
$req[$k]['type'] = '大货';
break;
case 5:
$req[$k]['type'] = '面料试样';
break;
case 6:
$req[$k]['type'] = '售后订单';
break;
}
} $csv_data = '';
//标题
$csv_data .= "门店,集团,经销商,订单类型,成衣数量,成衣+功能数量,制衣数量,制衣+功能数量,后整理加工,日期\r\n"; $row = array();
foreach ($req as $k=>$val){
$row['store_name'] = $val['store_name'];
$row['bloc_name'] = $val['bloc_name'];
$row['dealer_name'] = $val['dealer_name'];
$row['type'] = $val['type'];
$row['garment'] = $val['garment'];
$row['garment_function'] = $val['garment_function'];
$row['clothing'] = $val['clothing'];
$row['clothing_function'] = $val['clothing_function'];
$row['functional_finishing'] = $val['functional_finishing'];
$row['create_time'] = date('Y-m-d',$val['create_time']);
$csv_data .= join(',', array_values($row))."\r\n";
} $file_name = date('YmdHis', time()).'detail.csv';
//导出数据
$url = save_csv($file_name, $csv_data); $this->success('成功!','',$url);
exit();
} public function shijian(){ $list=$this->request->param();
//时间导出
$data=explode("- ",$list['data']); $data[0]=strtotime($data[0]);
$data[1]=strtotime($data[1]); $req=Db::name('cy_sum')
->alias('a')
->field('s.store_name,b.company_name as bloc_name,d.company_name as dealer_name,a.type,a.garment,a.garment_function,a.clothing,a.clothing_function,a.functional_finishing,a.create_time')
->join('store s','a.sid=s.id')
->join('bloc b','a.bid=b.id')
->join('dealer d','a.did=d.id')
->whereTime('a.create_time', 'between', [$data[0], $data[1]])
->select()
->toArray(); if (empty($req)){
$this->error('该时间段无数据 !');
} foreach ($req as $k=>$v){
switch ($req[$k]['type']) {
case 1:
$req[$k]['type'] = '定制';
break;
case 2:
$req[$k]['type'] = '定制团单';
break;
case 3:
$req[$k]['type'] = '样衣';
break;
case 4:
$req[$k]['type'] = '大货';
break;
case 5:
$req[$k]['type'] = '面料试样';
break;
case 6:
$req[$k]['type'] = '售后订单';
break;
} } $csv_data = '';
//标题
$csv_data .= "门店,集团,经销商,订单类型,成衣数量,成衣+功能数量,制衣数量,制衣+功能数量,后整理加工,日期\r\n"; $row = array();
foreach ($req as $k=>$val){
$row['store_name'] = $val['store_name'];
$row['bloc_name'] = $val['bloc_name'];
$row['dealer_name'] = $val['dealer_name'];
$row['type'] = $val['type'];
$row['garment'] = $val['garment'];
$row['garment_function'] = $val['garment_function'];
$row['clothing'] = $val['clothing'];
$row['clothing_function'] = $val['clothing_function'];
$row['functional_finishing'] = $val['functional_finishing'];
$row['create_time'] = date('Y-m-d',$val['create_time']);
$csv_data .= join(',', array_values($row))."\r\n";
} $file_name = date('YmdHis', time()).'detail.csv';
//导出数据
$url = save_csv($file_name, $csv_data); $this->success('成功!','',$url);
exit();
/**
* @param $file_name //请求参数 文件名
* @param $content //请求参数 根据内容
* @return url
* 保存文件导出csv
*/
function save_csv($file_name,$content){
$content = mb_convert_encoding($content, "cp936", "UTF-8");
//这里的CSV即你项目的根目录下新建一个CSV文件夹
//我们给每个用户动态的创建一个文件夹
$file_path = 'CSV/'.date('Ymd', time());
//判断该用户文件夹是否已经有这个文件夹
if(!file_exists("./upload/".$file_path)) {
mkdir("./upload/".$file_path, 0777, true);
}
$path = ('./upload/'.$file_path.'/'.$file_name);
$fp = fopen($path,'a');
// 写入并关闭资源
fwrite($fp, $content);
fclose($fp);
$path = cmf_get_root() . '/upload/' .$file_path.'/'.$file_name;
return $path;
}
/**
* 获取网站根目录
* @return string 网站根目录
*/
function cmf_get_root()
{
$request = Request::instance();
$root = $request->root();
$root = str_replace('/index.php', '', $root);
if (defined('APP_NAMESPACE') && APP_NAMESPACE == 'api') {
$root = preg_replace('/\/api$/', '', $root);
$root = rtrim($root, '/');
} return $root;
}

无论导出多大的数据,都不会出现乱码

PHP csv导出数据的更多相关文章

  1. PHP csv导出数据 (二)

    全部导出和时间导出 html代码,全程并不需要引用什么插件 <include file="public@header"/> <link href="__ ...

  2. Thinkphp解决phpExcel导出数据量大导致内存溢出

    工作需要导出几万的数据量.操作比较频繁.之前数据在七八千是数据导出很慢.phpExcel是方便但是性能一般.现在改为使用csv导出数据:可以缓解内存压力,一次导出两三万是没问题的.当然服务器内存给力, ...

  3. mysql导入导出.csv格式数据

    window下导入数据: LOAD DATA INFILE "C:\\1.csv" REPLACE INTO TABLE demo CHARACTER SET gb2312 FIE ...

  4. PHP导出数据到CSV文件函数 csv_export()

    后台往往需要导出各种数据到 Excel文档中.通常我们是导出 .csv文件格式,PHP导出函数参考代码如下: /** * 导出数据到CSV文件 * * @param array $data 二维数组( ...

  5. PHP导出数据到CSV文件函数/方法

    如果不清楚什么是CSV文件,可看如下文章介绍  CSV格式的是什么文件?CSV是什么的缩写? /** * 导出数据到CSV文件 * @param array $data 数据 * @param arr ...

  6. PHP导出数据到CSV文件

    后台往往需要导出各种数据到 Excel文档中.通常我们是导出 .csv文件格式,PHP导出函数参考代码如下: /** * 导出数据到CSV文件 * * @param array $data 二维数组( ...

  7. 导出数据之CSV

    平常开发中,常见的需求就是导出数据为Excel,CSV格式的表格.所以,在此记录一下导出CSV数据的小方法 $fileName = 'demo.csv'; $data = [ ['id'=>1, ...

  8. Bash中使用MySQL导入导出CSV格式数据[转]

    转自: http://codingstandards.iteye.com/blog/604541 MySQL中导出CSV格式数据的SQL语句样本如下:   select * from test_inf ...

  9. CSV文件数据如何读取、导入、导出到新的CSV文件中以及CSV文件的创建

    CSV文件数据如何读取.导入.导出到新的CSV文件中以及CSV文件的创建 一.csv文件的创建 (1)新建一个文本文档: 打开新建文本文档,进行编辑. 注意:关键字与关键字之间用英文半角逗号隔开.第一 ...

随机推荐

  1. android 自定义gridview(导航)

    最近又重新做回安卓,做了个小项目.下绝心使用android studio,通过这一回实战,终于用上了.综合了前人的经验,搞了个自己满意的导航界面,用的是gridview. 代码: package co ...

  2. (三)golang--执行流程分析

    XXX.go--go build XXX.go--XXX.exe XXX.go--go run XXX.go 两种方式的区别:(1)如果我们先编译生成了可执行文件,那么我们可以将该可执行文件拷贝到没g ...

  3. python读写符号的含义

    r 打开只读文件,该文件必须存在. r+ 打开可读写的文件,该文件必须存在. w 打开只写文件,若文件存在则文件长度清为0,即该文件内容会消失.若文件不存在则建立该文件. w+ 打开可读写文件,若文件 ...

  4. 大话设计模式Python实现-装饰模式

    装饰模式(Decorator Pattern):动态的给一个对象添加一些额外的职责,就增加功能来说,装饰模式比生成子类更为灵活. 下面是一个给人穿衣服的过程,使用装饰模式: #!/usr/bin/en ...

  5. 《Interest Rate Risk Modeling》阅读笔记——第五章:久期向量模型

    目录 第五章:久期向量模型 思维导图 久期向量的推导 久期向量 广义久期向量 一些想法 第五章:久期向量模型 思维导图 久期向量的推导 \[ V_0 = \sum_{t=t_1}^{t_n} CF_t ...

  6. CentOS7 安装nginx-1.14.0

    nginx源码包:http://nginx.org/en/download.html 1.安装gcc gcc是用来编译下载下来的nginx源码 yum install gcc-c++ 2.安装pcre ...

  7. css设置手型光标

    因为现在主流浏览器是chrome,所以要尽量使用 cursor:pointer,不要使用 cursor:hand chrome下支持的鼠标样式 default 默认光标(通常是一个箭头) auto 默 ...

  8. centos6.5 安装openresty

    [1]centos6.5 安装openresty步骤 (1)基础依赖库安装 1.1 yum install pcre-devel openssl-devel gcc curl (2)openResty ...

  9. Spring Boot 一个依赖搞定 session 共享,没有比这更简单的方案了!

    有的人可能会觉得题目有点夸张,其实不夸张,题目没有使用任何修辞手法!认真读完本文,你就知道松哥说的是对的了! 在传统的单服务架构中,一般来说,只有一个服务器,那么不存在 Session 共享问题,但是 ...

  10. <compilation debug="true" targetFramework="4.5.2"> 报错解决方案

    有的时候新建项目,默认会选择比较高的 .net framework 版本如 4.5.2 有的时候发布项目就会遇到这个问题 解决的话 改成4.0就行了! 看你发布在哪里,如果在本地或者服务器,只要去下载 ...