PHP csv导出数据 (二)

全部导出和时间导出
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();

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


注意:请求方法必须是get请求,不能用post请求
//用户提现审核导出
public function check_daochu()
{ $req = Db::name('cash_out')->alias('c')
->field('ca.card_name,ca.card_no,c.add_time,c.actual_money')
->join('xcf_user_wallet uw', 'uw.user_id=c.user_id', 'left')
->join('xcf_cash_account ca', "ca.id=c.account_id", "left")
->join('xcf_users u', "u.user_id=c.user_id", "left")
->where('c.role_id', 1)
->where('c.status', 1)
->order('c.add_time desc')
->select();
// ["card_name"] => string(6) "王毅"
// ["card_no"] => string(11) "15327953555"
// ["add_time"] => string(19) "2019-10-22 15:46:34"
// ["actual_money"] => string(4) "2.47"
$csv_data = '';
//标题
$csv_data .= "姓名,支付宝账号,实际到账金额,提现时间\r\n"; $row = array();
foreach ($req as $k=>$val){
$row['store_name'] = $val['card_name'];
$row['bloc_name'] = $val['card_no'];
$row['dealer_name'] = $val['actual_money'];
$row['create_time'] =$val['add_time'];
$csv_data .= join(',', array_values($row))."\r\n";
} $file_name = date('Y-m-d H-i-s', time()).' 用户提现.csv';
//导出数据
$url = $this->csvExportWithBOM($file_name, $csv_data);
exit();
//$this->success('成功!','',$url);
// return $url;
//return json(['ok' => 'success']); } /**@param $filename
* 输出csv文件的文件名
* @param $data
* 要写入csv文件的内容,即经过csvGenerator处理过的字符串;
*/
public function csvExportWithBOM($filename='export.csv', $data)
{
$f=fopen("php://memory",'w');
fwrite($f, chr(0xEF).chr(0xBB).chr(0xBF).$data);//加入BOM头
fseek($f,0);
header('Content-Type: application/csv');
// 告知浏览器想要输出的是一个文件
header('Content-Disposition: attachment; filename="'.$filename.'";');
// make php send the generated csv lines to the browser
fpassthru($f); }

PHP csv导出数据 (二)的更多相关文章
- PHP csv导出数据
全部导出和时间导出 html代码,全程并不需要引用什么插件 <include file="public@header"/> <link href="__ ...
- Thinkphp解决phpExcel导出数据量大导致内存溢出
工作需要导出几万的数据量.操作比较频繁.之前数据在七八千是数据导出很慢.phpExcel是方便但是性能一般.现在改为使用csv导出数据:可以缓解内存压力,一次导出两三万是没问题的.当然服务器内存给力, ...
- PHP导出数据到CSV文件函数 csv_export()
后台往往需要导出各种数据到 Excel文档中.通常我们是导出 .csv文件格式,PHP导出函数参考代码如下: /** * 导出数据到CSV文件 * * @param array $data 二维数组( ...
- PHP导出数据到CSV文件
后台往往需要导出各种数据到 Excel文档中.通常我们是导出 .csv文件格式,PHP导出函数参考代码如下: /** * 导出数据到CSV文件 * * @param array $data 二维数组( ...
- CSV文件数据如何读取、导入、导出到新的CSV文件中以及CSV文件的创建
CSV文件数据如何读取.导入.导出到新的CSV文件中以及CSV文件的创建 一.csv文件的创建 (1)新建一个文本文档: 打开新建文本文档,进行编辑. 注意:关键字与关键字之间用英文半角逗号隔开.第一 ...
- mysql导入导出.csv格式数据
window下导入数据: LOAD DATA INFILE "C:\\1.csv" REPLACE INTO TABLE demo CHARACTER SET gb2312 FIE ...
- PHP导出数据到CSV文件函数/方法
如果不清楚什么是CSV文件,可看如下文章介绍 CSV格式的是什么文件?CSV是什么的缩写? /** * 导出数据到CSV文件 * @param array $data 数据 * @param arr ...
- 导出数据之CSV
平常开发中,常见的需求就是导出数据为Excel,CSV格式的表格.所以,在此记录一下导出CSV数据的小方法 $fileName = 'demo.csv'; $data = [ ['id'=>1, ...
- Bash中使用MySQL导入导出CSV格式数据[转]
转自: http://codingstandards.iteye.com/blog/604541 MySQL中导出CSV格式数据的SQL语句样本如下: select * from test_inf ...
随机推荐
- 两道CTF Web的题目
1.easyphp 1.1.题目描述 题目首先是一张不存在的图片 查看源码发现只有一句话 <img src="show.php?img=aGludC5qcGc=" width ...
- Python学习第四十天函数的装饰器用法
在软件开发的过程中,要遵循软件的一些原则封装的,不改变原有的代码的基础增加一些需求,python提供了装饰器来扩展函数功能,下面说说函数装饰器用法 def debug(func): def ...
- apache2.4 只允许合法域名访问网站 禁止使用ip、非法域名访问
1.ip访问禁用ip访问 只能对应端口有效<VirtualHost *:80> ServerName xx.xx.xx.xx ServerAlias * <Location /> ...
- Django:django-debug-toolbar模块
简介: Django的django-debug-toolbar 模块是一组可配置的面板,可显示有关当前请求/响应的各种调试信息,并在单击时显示有关面板内容的更多详细信息. GitHub源文件下载地址 ...
- mybatis复习笔记(1):
一.简介:什么是MyBatis 1.MyBatis是一款优秀的持久层框架,支持定制化SQL.存储过程以及高级映射.MyBatis避免了几乎所有的JDBC代码和手动设置参数以及获取结果集.MyBatis ...
- JavaScript基础4——省市联动
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...
- java 中Shallow Heap与Retained Heap的区别
Shallow Size Shallow Size是对象本身占据的内存的大小,不包含其引用的对象.对于常规对象(非数组)的Shallow Size由其成员变量的数量和类型来定,而数组的ShallowS ...
- unity2017 光照与渲染(二)FAQs
FAQ: 场景里的物体没有影子? 1)灯光是否开了影子 2)QualitySettings 中 shadows 的设置 3) 模型MeshRenderer 的 ReciveShadows 和 Cast ...
- 6-基于TMS320C6678、FPGA XC5VSX95T的6U CPCI 8路光纤信号处理卡
基于TMS320C6678.FPGA XC5VSX95T的6U CPCI 8路光纤信号处理卡 1.板卡概述 本板卡由我公司自主研发,基于CPCI架构,符合CPCI2.0标准,采用两片TI DSP T ...
- 如何从mysql备份中提取单张表数据
1.先提取备份数据中的前50行出来,查看一下备份数据格式 head -50 bakdb.sql > head50.txt 类似下面的数据是我们所需要提取的: / ...