Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
J
Jz-Php
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
图表
比较
统计图
议题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
PHP
Jz-Php
Commits
fc6a5764
提交
fc6a5764
authored
4月 24, 2020
作者:
chengye
提交者:
wangkr
4月 29, 2020
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
init useage branch
上级
22009fa8
显示空白字符变更
内嵌
并排
正在显示
2 个修改的文件
包含
2 行增加
和
1378 行删除
+2
-1378
.gitignore
.gitignore
+2
-0
Excel(1).php
application/admin/controller/Excel(1).php
+0
-1378
没有找到文件。
.gitignore
浏览文件 @
fc6a5764
...
...
@@ -13,6 +13,8 @@
/think
/config/database.php
/config/cache.php
/config/session.php
/config/cookie.php
/public/dist
/public/dist2
/public/static/uploads
...
...
application/admin/controller/Excel(1).php
deleted
100755 → 0
浏览文件 @
22009fa8
<?php
/**
* Created by PhpStorm.
* User: chouchou
* Date: 2019-6-23
* Time: 23:53
*/
namespace
app\admin\controller
;
use
PhpOffice\PhpSpreadsheet\Reader\Xlsx
;
use
PhpOffice\PhpSpreadsheet\Reader\Xls
;
use
PhpOffice\PhpSpreadsheet\IOFactory
;
use
PhpOffice\PhpSpreadsheet\Cell\Coordinate
;
use
PhpOffice\PhpSpreadsheet\Spreadsheet
;
use
PhpOffice\PhpSpreadsheet\Worksheet\PageSetup
;
use
PhpOffice\PhpSpreadsheet\Cell\DataType
;
use
PhpOffice\PhpSpreadsheet\Style\Fill
;
use
PhpOffice\PhpSpreadsheet\Style\Color
;
use
PhpOffice\PhpSpreadsheet\Style\Alignment
;
use
PhpOffice\PhpSpreadsheet\Style\Border
;
use
PhpOffice\PhpSpreadsheet\Style\NumberFormat
;
use
PhpOffice\PhpSpreadsheet\Shared\Date
;
use
app\admin\model\StaffModel
;
use
app\admin\model\ElectricMeter
;
use
app\admin\model\BaseStationModel
;
use
think\facade\Session
;
use
think\Controller
;
use
think\Db
;
class
Excel
extends
Controller
{
/**
* 使用PHPEXECL导入
*
* @param string $file 文件地址
* @param int $sheet 工作表sheet(传0则获取第一个sheet)
* @param int $columnCnt 列数(传0则自动获取最大列)
* @param array $options 操作选项
* array mergeCells 合并单元格数组
* array formula 公式数组
* array format 单元格格式数组
*
* @return array
* @throws Exception
*/
public
function
importExecl
(
string
$file
=
''
,
int
$sheet
=
0
,
int
$columnCnt
=
0
,
&
$options
=
[])
{
ini_set
(
'memory_limit'
,
'1000M'
);
$extension
=
strtolower
(
pathinfo
(
$file
,
PATHINFO_EXTENSION
));
//判断导入表格后缀格式
// 有Xls和Xlsx格式两种
if
(
$extension
==
'xlsx'
)
{
$objReader
=
IOFactory
::
createReader
(
'Xlsx'
);
$objPHPExcel
=
$objReader
->
load
(
$file
);
}
elseif
(
$extension
==
'xls'
){
$objReader
=
IOFactory
::
createReader
(
'Xls'
);
$objPHPExcel
=
$objReader
->
load
(
$file
);
}
else
{
$this
->
error
(
'必须为excel表格,且必须为xls或者xlsx格式!'
);
}
//$filename可以是上传的表格,或者是指定的表格
$sheet
=
$objPHPExcel
->
getSheet
(
0
);
//excel中的第一张sheet
$highestRow
=
$sheet
->
getHighestRow
();
// 取得总行数
// $highestColumn = $sheet->getHighestColumn(); // 取得总列数
if
(
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"A1"
)
->
getValue
()
!==
'基站编号'
){
return
[
'code'
=>
5
,
'message'
=>
'模板错误'
];
}
if
(
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"B1"
)
->
getValue
()
!==
'基站名称'
){
return
[
'code'
=>
5
,
'message'
=>
'模板错误'
];
}
if
(
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"C1"
)
->
getValue
()
!==
'项目编号'
){
return
[
'code'
=>
5
,
'message'
=>
'模板错误'
];
}
if
(
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"D1"
)
->
getValue
()
!==
'电表类型'
){
return
[
'code'
=>
5
,
'message'
=>
'模板错误'
];
}
if
(
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"E1"
)
->
getValue
()
!==
'电表识别号'
){
return
[
'code'
=>
5
,
'message'
=>
'模板错误'
];
}
if
(
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"F1"
)
->
getValue
()
!==
'缴费号'
){
return
[
'code'
=>
5
,
'message'
=>
'模板错误'
];
}
if
(
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"G1"
)
->
getValue
()
!==
'倍率'
){
return
[
'code'
=>
5
,
'message'
=>
'模板错误'
];
}
if
(
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"H1"
)
->
getValue
()
!==
'电表初始度数'
){
return
[
'code'
=>
5
,
'message'
=>
'模板错误'
];
}
if
(
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"I1"
)
->
getValue
()
!==
'电表备注'
){
return
[
'code'
=>
5
,
'message'
=>
'模板错误'
];
}
if
(
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"J1"
)
->
getValue
()
!==
'电表初始充值金额'
){
return
[
'code'
=>
5
,
'message'
=>
'模板错误'
];
}
if
(
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"K1"
)
->
getValue
()
!==
'抄表单单价'
){
return
[
'code'
=>
5
,
'message'
=>
'模板错误'
];
}
if
(
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"L1"
)
->
getValue
()
!==
'首次查表日期'
){
return
[
'code'
=>
5
,
'message'
=>
'模板错误'
];
}
if
(
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"M1"
)
->
getValue
()
!==
'是否协议价'
){
return
[
'code'
=>
5
,
'message'
=>
'模板错误'
];
}
if
(
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"N1"
)
->
getValue
()
!==
'协议价'
){
return
[
'code'
=>
5
,
'message'
=>
'模板错误'
];
}
if
(
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"O1"
)
->
getValue
()
!==
'协议名称'
){
return
[
'code'
=>
5
,
'message'
=>
'模板错误'
];
}
if
(
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"P1"
)
->
getValue
()
!==
'协议编号'
){
return
[
'code'
=>
5
,
'message'
=>
'模板错误'
];
}
if
(
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"Q1"
)
->
getValue
()
!==
'开始时间'
){
return
[
'code'
=>
5
,
'message'
=>
'模板错误'
];
}
if
(
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"R1"
)
->
getValue
()
!==
'结束时间'
){
return
[
'code'
=>
5
,
'message'
=>
'模板错误'
];
}
if
(
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"S1"
)
->
getValue
()
!==
'签订日期'
){
return
[
'code'
=>
5
,
'message'
=>
'模板错误'
];
}
if
(
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"T1"
)
->
getValue
()
!==
'协议备注'
){
return
[
'code'
=>
5
,
'message'
=>
'模板错误'
];
}
if
(
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"U1"
)
->
getValue
()
!==
'缴费周期'
){
return
[
'code'
=>
5
,
'message'
=>
'模板错误'
];
}
if
(
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"V1"
)
->
getValue
()
!==
'业务员'
){
return
[
'code'
=>
5
,
'message'
=>
'模板错误'
];
}
if
(
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"W1"
)
->
getValue
()
!==
'电表地址'
){
return
[
'code'
=>
5
,
'message'
=>
'模板错误'
];
}
if
(
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"X1"
)
->
getValue
()
!==
'甲方联系人'
){
return
[
'code'
=>
5
,
'message'
=>
'模板错误'
];
}
if
(
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"Y1"
)
->
getValue
()
!==
'甲方联系方式'
){
return
[
'code'
=>
5
,
'message'
=>
'模板错误'
];
}
if
(
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"Z1"
)
->
getValue
()
!==
'机房位置'
){
return
[
'code'
=>
5
,
'message'
=>
'模板错误'
];
}
if
(
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"AA1"
)
->
getValue
()
!==
'物业位置'
){
return
[
'code'
=>
5
,
'message'
=>
'模板错误'
];
}
if
(
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"AB1"
)
->
getValue
()
!==
'收款单位'
){
return
[
'code'
=>
5
,
'message'
=>
'模板错误'
];
}
if
(
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"AC1"
)
->
getValue
()
!==
'出租单位名称'
){
return
[
'code'
=>
5
,
'message'
=>
'模板错误'
];
}
if
(
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"AD1"
)
->
getValue
()
!==
'机房备注'
){
return
[
'code'
=>
5
,
'message'
=>
'模板错误'
];
}
if
(
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"AE1"
)
->
getValue
()
!==
'合同编号'
){
return
[
'code'
=>
5
,
'message'
=>
'模板错误'
];
}
if
(
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"AF1"
)
->
getValue
()
!==
'确认合同日期'
){
return
[
'code'
=>
5
,
'message'
=>
'模板错误'
];
}
if
(
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"AG1"
)
->
getValue
()
!==
'合同有效时间'
){
return
[
'code'
=>
5
,
'message'
=>
'模板错误'
];
}
if
(
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"AH1"
)
->
getValue
()
!==
'机房二维码'
){
return
[
'code'
=>
5
,
'message'
=>
'模板错误'
];
}
$usersExits
=
[];
//循环读取excel表格,整合成数组。如果是不指定key的二维,就用$data[i][j]表示。
$create_time
=
time
();
$electric_meter
[
'create_time'
]
=
$create_time
;
$contract
[
'create_time'
]
=
$create_time
;
$agreement
[
'create_time'
]
=
$create_time
;
$engine_room
[
'create_time'
]
=
$create_time
;
$electric_meter
[
'update_time'
]
=
$create_time
;
$contract
[
'update_time'
]
=
$create_time
;
$agreement
[
'update_time'
]
=
$create_time
;
$engine_room
[
'update_time'
]
=
$create_time
;
for
(
$j
=
2
;
$j
<=
$highestRow
;
$j
++
)
{
//站号
$station_sp_code
=
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"A"
.
$j
)
->
getValue
();
//站名
$station_name
=
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"B"
.
$j
)
->
getValue
();
//项目编号
$proj_number
=
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"C"
.
$j
)
->
getValue
();
//通过站号 、站名、项目编号确认电表的station_id
$electric_meter
[
'station_id'
]
=
(
new
ElectricMeter
)
->
getStationID
(
$proj_number
);
//电表类型 electric_meter
$emt_id
=
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"D"
.
$j
)
->
getValue
();
$electric_meter
[
'emt_id'
]
=
(
new
ElectricMeter
)
->
getEmtId
(
$emt_id
);
//电表识别号 electric_meter
$number
=
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"E"
.
$j
)
->
getValue
();
$electric_meter
[
'number'
]
=
isset
(
$number
)
?
$number
:
''
;
//缴费号 electric_meter
$pay_number
=
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"F"
.
$j
)
->
getValue
();
$electric_meter
[
'pay_number'
]
=
isset
(
$pay_number
)
?
$pay_number
:
''
;
//倍率 electric_meter
$multiple
=
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"G"
.
$j
)
->
getValue
();
$electric_meter
[
'multiple'
]
=
isset
(
$multiple
)
?
$multiple
:
''
;
//电表初始度数 electric_meter
$init_degree
=
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"H"
.
$j
)
->
getValue
();
$electric_meter
[
'init_degree'
]
=
isset
(
$init_degree
)
?
$init_degree
:
''
;
//电表备注 electric_meter
$text
=
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"I"
.
$j
)
->
getValue
();
$electric_meter
[
'remark'
]
=
isset
(
$text
)
?
$text
:
''
;
//电表初始充值金额 init_amount
$init_amount
=
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"J"
.
$j
)
->
getValue
();
$electric_meter
[
'init_amount'
]
=
isset
(
$init_amount
)
?
$init_amount
:
0
;
//抄表单单价 electric_meter
$unit_price
=
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"K"
.
$j
)
->
getValue
();
$electric_meter
[
'unit_price'
]
=
isset
(
$unit_price
)
?
$unit_price
:
''
;
//首次查表日期 转换为时间戳first_cp_date electric_meter
// $first_cp_date= $objPHPExcel->getActiveSheet()->getCell("L".$j)->getValue();
$first_cp_date
=
Date
::
excelToTimestamp
(
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"L"
.
$j
)
->
getValue
());
$electric_meter
[
'first_cp_date'
]
=
isset
(
$first_cp_date
)
?
$first_cp_date
:
''
;
//是否协议价 electric_meter
$is_protocol
=
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"M"
.
$j
)
->
getValue
();
if
(
$is_protocol
==
'是'
){
$electric_meter
[
'is_protocol'
]
=
1
;
}
else
{
$electric_meter
[
'is_protocol'
]
=
0
;
}
//协议价 electric_meter
$protocol_price
=
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"N"
.
$j
)
->
getValue
();
$electric_meter
[
'protocol_price'
]
=
isset
(
$protocol_price
)
?
$protocol_price
:
''
;
//协议名称
$contract_name
=
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"O"
.
$j
)
->
getValue
();
$agreement
[
'name'
]
=
isset
(
$contract_name
)
?
$contract_name
:
''
;
//协议编号
$contract_number
=
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"P"
.
$j
)
->
getValue
();
$agreement
[
'number'
]
=
isset
(
$contract_number
)
?
$contract_number
:
''
;
//开始时间
$contract_start_date
=
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"Q"
.
$j
)
->
getValue
();
if
(
$contract_start_date
){
$agreement
[
'start_time'
]
=
Date
::
excelToTimestamp
(
$contract_start_date
);
}
else
{
$agreement
[
'start_time'
]
=
0
;
}
//结束时间
$contract_end_date
=
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"R"
.
$j
)
->
getValue
();
if
(
$contract_end_date
){
$agreement
[
'end_time'
]
=
Date
::
excelToTimestamp
(
$contract_end_date
);
}
else
{
$agreement
[
'end_time'
]
=
0
;
}
//签订日期
$contract_sign_date
=
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"S"
.
$j
)
->
getValue
();
if
(
$contract_sign_date
){
$agreement
[
'sign_time'
]
=
Date
::
excelToTimestamp
(
$contract_sign_date
);
}
else
{
$agreement
[
'sign_time'
]
=
0
;
}
//协议备注
$contract_remark
=
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"T"
.
$j
)
->
getValue
();
$agreement
[
'remark'
]
=
isset
(
$contract_remark
)
?
$contract_remark
:
''
;
// 缴费周期 electric_meter
$pay_cycle
=
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"U"
.
$j
)
->
getValue
();
$electric_meter
[
'pay_cycle'
]
=
isset
(
$pay_cycle
)
?
$pay_cycle
:
''
;
//业务员 electric_meter
$staff_id
=
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"V"
.
$j
)
->
getValue
();
$electric_meter
[
'staff_id'
]
=
(
new
ElectricMeter
)
->
getStaffId
(
$staff_id
);
//电表地址 electric_meter
$address
=
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"W"
.
$j
)
->
getValue
();
$electric_meter
[
'address'
]
=
isset
(
$address
)
?
$address
:
''
;
//合同附件id
$electric_meter
[
'photo_id'
]
=
1
;
//甲方联系人 engine_room
$contact
=
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"X"
.
$j
)
->
getValue
();
$engine_room
[
'contact'
]
=
isset
(
$contact
)
?
$contact
:
''
;
//甲方联系方式 engine_room
$tel
=
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"Y"
.
$j
)
->
getValue
();
$engine_room
[
'tel'
]
=
isset
(
$tel
)
?
$tel
:
''
;
$engine_room
[
'station_id'
]
=
$electric_meter
[
'station_id'
];
//机房位置 engine_room
$position
=
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"Z"
.
$j
)
->
getValue
();
$engine_room
[
'position'
]
=
isset
(
$position
)
?
$position
:
''
;
//物业位置 engine_room
$property_position
=
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"AA"
.
$j
)
->
getValue
();
$engine_room
[
'property_position'
]
=
isset
(
$property_position
)
?
$property_position
:
''
;
// 实际收款单位 engine_room
$receive
=
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"AB"
.
$j
)
->
getValue
();
$engine_room
[
'receive'
]
=
isset
(
$receive
)
?
$receive
:
''
;
//出租单位名称 engine_room
$rent
=
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"AC"
.
$j
)
->
getValue
();
$engine_room
[
'rent'
]
=
isset
(
$rent
)
?
$rent
:
''
;
//机房名称
$engine_room
[
'name'
]
=
isset
(
$rent
)
?
$rent
:
''
;
//机房备注 engine_room
$remark
=
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"AD"
.
$j
)
->
getValue
();
$engine_room
[
'remark'
]
=
isset
(
$remark
)
?
$remark
:
''
;
//合同编号 contract
$number
=
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"AE"
.
$j
)
->
getValue
();
$contract
[
'number'
]
=
isset
(
$number
)
?
$number
:
'contract-add-000000'
;
//确认合同日期 contract
//业务员id
$agreement
[
'u_id'
]
=
$electric_meter
[
'staff_id'
];
$agreement
[
'type'
]
=
2
;
$agreement
[
'file_id'
]
=
1
;
$agreement
[
'd_id'
]
=
(
new
ElectricMeter
)
->
getDepartId
(
$electric_meter
[
'staff_id'
]);
$agreement
[
'file_id'
]
=
0
;
$time
=
$contract_end_date
-
$contract_start_date
;
$agreement
[
'period'
]
=
ceil
(
$time
/
(
3600
*
24
*
30
));
$sign_date
=
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"AF"
.
$j
)
->
getValue
();
if
(
$sign_date
){
$contract
[
'start_time'
]
=
Date
::
excelToTimestamp
(
$sign_date
);
$contract
[
'end_time'
]
=
Date
::
excelToTimestamp
(
$sign_date
);
$contract
[
'sign_time'
]
=
Date
::
excelToTimestamp
(
$sign_date
);
}
else
{
$contract
[
'start_time'
]
=
0
;
$contract
[
'end_time'
]
=
0
;
$contract
[
'sign_time'
]
=
0
;
}
//合同有效时间 contract
$period
=
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"AG"
.
$j
)
->
getValue
();
$contract
[
'period'
]
=
isset
(
$period
)
?
$period
:
''
;
$qrcode
=
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"AH"
.
$j
)
->
getValue
();
$electric_meter
[
'qrcode'
]
=
isset
(
$qrcode
)
?
$qrcode
:
''
;
$contract
[
'name'
]
=
'新增电表合同'
;
$contract
[
'u_id'
]
=
$electric_meter
[
'staff_id'
];
$contract
[
'd_id'
]
=
(
new
ElectricMeter
)
->
getDepartId
(
$electric_meter
[
'staff_id'
]);;
$contract
[
'type'
]
=
1
;
$contract
[
'file_id'
]
=
0
;
$contract
[
'remark'
]
=
''
;
$electricMeterAll
[]
=
$electric_meter
;
$contractAll
[]
=
$contract
;
$agreementAll
[]
=
$agreement
;
$engineRoomAll
[]
=
$engine_room
;
}
Db
::
name
(
'contract'
)
->
insertAll
(
$contractAll
);
Db
::
name
(
'engine_room'
)
->
insertAll
(
$engineRoomAll
);
Db
::
name
(
'contract'
)
->
insertAll
(
$agreementAll
);
$contractID
=
Db
::
name
(
'contract'
)
->
field
(
'id'
)
->
where
(
"create_time='
$create_time
'"
)
->
select
();
$engineRoomID
=
Db
::
name
(
'engine_room'
)
->
field
(
'id'
)
->
where
(
"create_time='
$create_time
'"
)
->
order
(
'id asc'
)
->
select
();
$agreementID
=
Db
::
name
(
'contract'
)
->
field
(
'id'
)
->
where
(
"create_time='
$create_time
' and type=2"
)
->
select
();
$electricMeterAllList
=
array
();
foreach
(
$electricMeterAll
as
$key
=>
$val
){
$electricMeterAllList
[]
=
array_merge
(
$val
,
array
(
'er_id'
=>
$engineRoomID
[
$key
][
'id'
]));
}
foreach
(
$electricMeterAllList
as
$key
=>
$value
)
{
$electricMeterAllListb
[]
=
array_merge
(
$value
,
array
(
'contract_id'
=>
$contractID
[
$key
][
'id'
]));
}
foreach
(
$electricMeterAllListb
as
$key
=>
$value
)
{
$electricMeterAllListc
[]
=
array_merge
(
$value
,
array
(
'protocol_id'
=>
$agreementID
[
$key
][
'id'
]));
}
$sucelectric
=
Db
::
name
(
'electric_meter'
)
->
insertAll
(
$electricMeterAllListc
);
$data
[
'total'
]
=
$highestRow
-
1
;
$data
[
'suc'
]
=
$sucelectric
;
$data
[
'er'
]
=
$highestRow
-
1
-
$sucelectric
;
return
[
'code'
=>
200
,
'message'
=>
'导入成功'
,
'data'
=>
$data
];
}
//基站信息导入
public
function
baseExecl
(
string
$file
=
''
,
int
$sheet
=
0
,
int
$columnCnt
=
0
,
&
$options
=
[])
{
ini_set
(
'memory_limit'
,
'1000M'
);
$extension
=
strtolower
(
pathinfo
(
$file
,
PATHINFO_EXTENSION
));
//判断导入表格后缀格式
// 有Xls和Xlsx格式两种
if
(
$extension
==
'xlsx'
)
{
$objReader
=
IOFactory
::
createReader
(
'Xlsx'
);
$objPHPExcel
=
$objReader
->
load
(
$file
);
}
elseif
(
$extension
==
'xls'
){
$objReader
=
IOFactory
::
createReader
(
'Xls'
);
$objPHPExcel
=
$objReader
->
load
(
$file
);
}
else
{
$this
->
error
(
'必须为excel表格,且必须为xls或者xlsx格式!'
);
}
//$filename可以是上传的表格,或者是指定的表格
$sheet
=
$objPHPExcel
->
getSheet
(
0
);
//excel中的第一张sheet
$highestRow
=
$sheet
->
getHighestRow
();
// 取得总行数
// $highestColumn = $sheet->getHighestColumn(); // 取得总列数
if
(
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"A1"
)
->
getValue
()
!==
'基站名称'
){
return
[
'code'
=>
5
,
'message'
=>
'模板错误'
];
}
if
(
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"B1"
)
->
getValue
()
!==
'基站编号'
){
return
[
'code'
=>
5
,
'message'
=>
'模板错误'
];
}
if
(
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"C1"
)
->
getValue
()
!==
'项目编号'
){
return
[
'code'
=>
5
,
'message'
=>
'模板错误'
];
}
if
(
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"D1"
)
->
getValue
()
!==
'需求号'
){
return
[
'code'
=>
5
,
'message'
=>
'模板错误'
];
}
if
(
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"E1"
)
->
getValue
()
!==
'运营商'
){
return
[
'code'
=>
5
,
'message'
=>
'模板错误'
];
}
if
(
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"F1"
)
->
getValue
()
!==
'业务线'
){
return
[
'code'
=>
5
,
'message'
=>
'模板错误'
];
}
if
(
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"G1"
)
->
getValue
()
!==
'区域'
){
return
[
'code'
=>
5
,
'message'
=>
'模板错误'
];
}
if
(
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"H1"
)
->
getValue
()
!==
'基站状态'
){
return
[
'code'
=>
5
,
'message'
=>
'模板错误'
];
}
if
(
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"I1"
)
->
getValue
()
!==
'经度'
){
return
[
'code'
=>
5
,
'message'
=>
'模板错误'
];
}
if
(
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"J1"
)
->
getValue
()
!==
'纬度'
){
return
[
'code'
=>
5
,
'message'
=>
'模板错误'
];
}
if
(
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"K1"
)
->
getValue
()
!==
'项目地址'
){
return
[
'code'
=>
5
,
'message'
=>
'模板错误'
];
}
if
(
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"L1"
)
->
getValue
()
!==
'墙面天线数'
){
return
[
'code'
=>
5
,
'message'
=>
'模板错误'
];
}
if
(
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"M1"
)
->
getValue
()
!==
'杆数'
){
return
[
'code'
=>
5
,
'message'
=>
'模板错误'
];
}
if
(
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"N1"
)
->
getValue
()
!==
'箱体数'
){
return
[
'code'
=>
5
,
'message'
=>
'模板错误'
];
}
if
(
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"O1"
)
->
getValue
()
!==
'光缆公里数'
){
return
[
'code'
=>
5
,
'message'
=>
'模板错误'
];
}
if
(
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"P1"
)
->
getValue
()
!==
'RRU数量'
){
return
[
'code'
=>
5
,
'message'
=>
'模板错误'
];
}
if
(
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"Q1"
)
->
getValue
()
!==
'RRU方位角'
){
return
[
'code'
=>
5
,
'message'
=>
'模板错误'
];
}
if
(
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"R1"
)
->
getValue
()
!==
'施工队类型'
){
return
[
'code'
=>
5
,
'message'
=>
'模板错误'
];
}
if
(
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"S1"
)
->
getValue
()
!==
'施工联系方式'
){
return
[
'code'
=>
5
,
'message'
=>
'模板错误'
];
}
if
(
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"T1"
)
->
getValue
()
!==
'部门'
){
return
[
'code'
=>
5
,
'message'
=>
'模板错误'
];
}
if
(
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"U1"
)
->
getValue
()
!==
'经理'
){
return
[
'code'
=>
5
,
'message'
=>
'模板错误'
];
}
if
(
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"V1"
)
->
getValue
()
!==
'业务员'
){
return
[
'code'
=>
5
,
'message'
=>
'模板错误'
];
}
if
(
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"W1"
)
->
getValue
()
!==
'需求来源'
){
return
[
'code'
=>
5
,
'message'
=>
'模板错误'
];
}
if
(
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"X1"
)
->
getValue
()
!==
'公司上游客户'
){
return
[
'code'
=>
5
,
'message'
=>
'模板错误'
];
}
if
(
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"Y1"
)
->
getValue
()
!==
'频段'
){
return
[
'code'
=>
5
,
'message'
=>
'模板错误'
];
}
if
(
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"Z1"
)
->
getValue
()
!==
'创建时间'
){
return
[
'code'
=>
5
,
'message'
=>
'模板错误'
];
}
$usersExits
=
[];
//循环读取excel表格,整合成数组。如果是不指定key的二维,就用$data[i][j]表示。
$create_time
=
time
();
$station
[
'update_time'
]
=
$create_time
;
$detai
[
'update_time'
]
=
$create_time
;
$vendor
[
'update_time'
]
=
$create_time
;
for
(
$j
=
2
;
$j
<=
$highestRow
;
$j
++
)
{
//基站名称
$station_name
=
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"A"
.
$j
)
->
getValue
();
$station
[
'station_name'
]
=
isset
(
$station_name
)
?
$station_name
:
''
;
//基站编号
$station_sp_code
=
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"B"
.
$j
)
->
getValue
();
$station
[
'station_sp_code'
]
=
isset
(
$station_sp_code
)
?
$station_sp_code
:
''
;
// 项目编号
$proj_number
=
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"C"
.
$j
)
->
getValue
();
if
(
empty
(
$proj_number
)){
return
[
'code'
=>
7
,
'message'
=>
'项目编号不能为空'
];
}
$ojnumber
=
(
new
BaseStationModel
)
->
getproId
(
$proj_number
);
if
(
$ojnumber
){
return
[
'code'
=>
8
,
'message'
=>
'该项目编号:'
.
$proj_number
.
'已存在,不能重复添加'
];
}
$station
[
'proj_number'
]
=
$proj_number
;
//需求号
$sp_req_code
=
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"D"
.
$j
)
->
getValue
();
$station
[
'sp_req_code'
]
=
isset
(
$sp_req_code
)
?
$sp_req_code
:
''
;
//运营商
$original_sp_id
=
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"E"
.
$j
)
->
getValue
();
if
(
$original_sp_id
){
$station
[
'original_sp_id'
]
=
(
new
BaseStationModel
)
->
getoriginalById
(
$original_sp_id
);
}
else
{
$station
[
'original_sp_id'
]
=
0
;
}
//业务线
$business_line_id
=
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"F"
.
$j
)
->
getValue
();
if
(
$business_line_id
){
$station
[
'business_line_id'
]
=
(
new
BaseStationModel
)
->
getbussById
(
$business_line_id
);
}
else
{
$station
[
'business_line_id'
]
=
0
;
}
//区域
$area_id
=
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"G"
.
$j
)
->
getValue
();
if
(
$area_id
){
$station
[
'area_id'
]
=
(
new
BaseStationModel
)
->
getregionById
(
$area_id
);
}
else
{
$station
[
'area_id'
]
=
0
;
}
//基站状态
$base_station_state
=
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"H"
.
$j
)
->
getValue
();
if
(
$base_station_state
){
$station
[
'base_station_state'
]
=
(
new
BaseStationModel
)
->
getstatusById
(
$base_station_state
);
}
else
{
$station
[
'base_station_state'
]
=
0
;
}
//经度
$longitude
=
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"I"
.
$j
)
->
getValue
();
$detai
[
'longitude'
]
=
isset
(
$longitude
)
?
$longitude
:
''
;
//纬度
$latitude
=
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"J"
.
$j
)
->
getValue
();
$detai
[
'latitude'
]
=
isset
(
$latitude
)
?
$latitude
:
''
;
// 项目地址
$location
=
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"K"
.
$j
)
->
getValue
();
$station
[
'location'
]
=
isset
(
$location
)
?
$location
:
''
;
// 墙面天线数
$antenna_number
=
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"L"
.
$j
)
->
getValue
();
$detai
[
'antenna_number'
]
=
isset
(
$antenna_number
)
?
$antenna_number
:
'0'
;
// 杆数
$rod_number
=
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"M"
.
$j
)
->
getValue
();
$detai
[
'rod_number'
]
=
isset
(
$rod_number
)
?
$rod_number
:
'0'
;
// 箱体数
$box_number
=
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"N"
.
$j
)
->
getValue
();
$detai
[
'box_number'
]
=
isset
(
$box_number
)
?
$box_number
:
'0'
;
// 光缆公里数
$optical_cable
=
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"O"
.
$j
)
->
getValue
();
$detai
[
'optical_cable'
]
=
isset
(
$optical_cable
)
?
$optical_cable
:
'0'
;
// RRU数量
$rru_number
=
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"P"
.
$j
)
->
getValue
();
$detai
[
'rru_number'
]
=
isset
(
$rru_number
)
?
$rru_number
:
'0'
;
// RRU方位角
$rru_zimuth
=
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"Q"
.
$j
)
->
getValue
();
$detai
[
'rru_zimuth'
]
=
isset
(
$rru_zimuth
)
?
$rru_zimuth
:
'0'
;
// 施工队类型
$type
=
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"R"
.
$j
)
->
getValue
();
if
(
$type
==
'自建'
){
$vendor
[
'type'
]
=
1
;
}
elseif
(
$type
==
'外围'
){
$vendor
[
'type'
]
=
2
;
}
elseif
(
$type
==
'挂靠'
){
$vendor
[
'type'
]
=
3
;
}
else
{
$vendor
[
'type'
]
=
0
;
}
// 施工联系方式
$construction_number
=
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"S"
.
$j
)
->
getValue
();
$vendor
[
'construction_number'
]
=
isset
(
$construction_number
)
?
$construction_number
:
''
;
// 部门
$department_id
=
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"T"
.
$j
)
->
getValue
();
if
(
$department_id
){
$station
[
'department_id'
]
=
(
new
BaseStationModel
)
->
getdepartById
(
$department_id
);
}
else
{
$station
[
'department_id'
]
=
0
;
}
// 经理
$three_level_manager
=
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"U"
.
$j
)
->
getValue
();
$vendor
[
'three_level_manager'
]
=
isset
(
$three_level_manager
)
?
$three_level_manager
:
''
;
// 业务员
$salesman
=
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"V"
.
$j
)
->
getValue
();
$vendor
[
'salesman'
]
=
isset
(
$salesman
)
?
$salesman
:
''
;
// 需求来源
$sources_id
=
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"W"
.
$j
)
->
getValue
();
if
(
$sources_id
){
$station
[
'sources_id'
]
=
(
new
BaseStationModel
)
->
getsourceId
(
$sources_id
);
}
else
{
$station
[
'sources_id'
]
=
0
;
}
// 公司上游客户
$customers_id
=
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"X"
.
$j
)
->
getValue
();
if
(
$customers_id
){
$station
[
'customers_id'
]
=
(
new
BaseStationModel
)
->
getcustomersId
(
$customers_id
);
}
else
{
$station
[
'customers_id'
]
=
0
;
}
// 频段
$frequencyband_id
=
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"Y"
.
$j
)
->
getValue
();
if
(
$frequencyband_id
){
$detai
[
'frequencyband_id'
]
=
(
new
BaseStationModel
)
->
getfrequencybandId
(
$frequencyband_id
);
}
else
{
$detai
[
'frequencyband_id'
]
=
0
;
}
$add_date
=
strtotime
(
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"Z"
.
$j
)
->
getValue
());
if
(
$add_date
){
$station
[
'create_time'
]
=
$add_date
;
$detai
[
'create_time'
]
=
$add_date
;
$vendor
[
'create_time'
]
=
$add_date
;
}
else
{
$station
[
'create_time'
]
=
$create_time
;
$detai
[
'create_time'
]
=
$create_time
;
$vendor
[
'create_time'
]
=
$create_time
;
}
$stationAll
[]
=
$station
;
$detaiAll
[]
=
$detai
;
$vendorAll
[]
=
$vendor
;
}
$sucelectric
=
Db
::
name
(
'station_info'
)
->
insertAll
(
$stationAll
);
$station_info
=
Db
::
name
(
'station_info'
)
->
field
(
'station_id,original_sp_id'
)
->
where
(
"update_time='
$create_time
'"
)
->
select
();
$detaiList
=
array
();
foreach
(
$detaiAll
as
$key
=>
$val
){
$value
=
array_merge
(
$val
,
array
(
'stationid'
=>
$station_info
[
$key
][
'station_id'
]));
$detaiList
[]
=
$value
;
}
Db
::
name
(
'station_info_detai'
)
->
insertAll
(
$detaiList
);
$vendinfoList
=
array
();
foreach
(
$vendorAll
as
$k
=>
$vo
){
$value
=
array_merge
(
$vo
,
array
(
'vendor_id'
=>
$station_info
[
$k
][
'station_id'
]));
$vendinfoList
[]
=
$value
;
}
Db
::
name
(
'vendor_info'
)
->
insertAll
(
$vendinfoList
);
$data
[
'total'
]
=
$highestRow
-
1
;
$data
[
'suc'
]
=
$sucelectric
;
$data
[
'er'
]
=
$highestRow
-
1
-
$sucelectric
;
return
[
'code'
=>
200
,
'message'
=>
'导入成功'
,
'data'
=>
$data
];
}
/**
* Excel导出,TODO 可继续优化
*
* @param array $datas 导出数据,格式['A1', => 'XXXX公司报表', 'B1' => '序号']
* @param string $fileName 导出文件名称
* @param array $options 操作选项,例如:
* bool print 设置打印格式
* string freezePane 锁定行数,例如表头为第一行,则锁定表头输入A2
* array setARGB 设置背景色,例如['A1',, 'C1']
* array setWidth 设置宽度,例如['A' => 30, 'C' => 20]
* bool setBorder 设置单元格边框
* array mergeCells 设置合并单元格,例如['A1:J1' => 'A1:J1']
* array formula 设置公式,例如['F2' => '=IF(D2>0,E42/D2,0)']
* array format 设置格式,整列设置,例如['A' => 'General']
* array alignCenter 设置居中样式,例如['A1',, 'A2']
* array bold 设置加粗样式,例如['A1',, 'A2']
* string savePath 保存路径,设置后则文件保存到服务器,不通过浏览器下载
*/
public
function
exportExcel
(
array
$datas
,
string
$fileName
=
''
,
array
$options
=
[])
:
bool
{
try
{
if
(
empty
(
$datas
))
{
return
false
;
}
set_time_limit
(
0
);
/** @var Spreadsheet $objSpreadsheet */
$objSpreadsheet
=
app
(
Spreadsheet
::
class
);
/* 设置默认文字居左,上下居中 */
$styleArray
=
[
'alignment'
=>
[
'horizontal'
=>
Alignment
::
HORIZONTAL_LEFT
,
'vertical'
=>
Alignment
::
VERTICAL_CENTER
,
],
];
$objSpreadsheet
->
getDefaultStyle
()
->
applyFromArray
(
$styleArray
);
/* 设置Excel Sheet */
$activeSheet
=
$objSpreadsheet
->
setActiveSheetIndex
(
0
);
/* 打印设置 */
if
(
isset
(
$options
[
'print'
])
&&
$options
[
'print'
])
{
/* 设置打印为A4效果 */
$activeSheet
->
getPageSetup
()
->
setPaperSize
(
PageSetup
::
PAPERSIZE_A4
);
/* 设置打印时边距 */
$pValue
=
1
/
2.54
;
$activeSheet
->
getPageMargins
()
->
setTop
(
$pValue
/
2
);
$activeSheet
->
getPageMargins
()
->
setBottom
(
$pValue
*
2
);
$activeSheet
->
getPageMargins
()
->
setLeft
(
$pValue
/
2
);
$activeSheet
->
getPageMargins
()
->
setRight
(
$pValue
/
2
);
}
/* 行数据处理 */
foreach
(
$datas
as
$sKey
=>
$sItem
)
{
/* 默认文本格式 */
$pDataType
=
DataType
::
TYPE_STRING
;
/* 设置单元格格式 */
if
(
isset
(
$options
[
'format'
])
&&
!
empty
(
$options
[
'format'
]))
{
$colRow
=
Coordinate
::
coordinateFromString
(
$sKey
);
/* 存在该列格式并且有特殊格式 */
if
(
isset
(
$options
[
'format'
][
$colRow
[
0
]])
&&
NumberFormat
::
FORMAT_GENERAL
!=
$options
[
'format'
][
$colRow
[
0
]])
{
$activeSheet
->
getStyle
(
$sKey
)
->
getNumberFormat
()
->
setFormatCode
(
$options
[
'format'
][
$colRow
[
0
]]);
if
(
false
!==
strpos
(
$options
[
'format'
][
$colRow
[
0
]],
'0.00'
)
&&
is_numeric
(
str_replace
([
'¥'
,
','
],
''
,
$sItem
)))
{
/* 数字格式转换为数字单元格 */
$pDataType
=
DataType
::
TYPE_NUMERIC
;
$sItem
=
str_replace
([
'¥'
,
','
],
''
,
$sItem
);
}
}
elseif
(
is_int
(
$sItem
))
{
$pDataType
=
DataType
::
TYPE_NUMERIC
;
}
}
$activeSheet
->
setCellValueExplicit
(
$sKey
,
$sItem
,
$pDataType
);
/* 存在:形式的合并行列,列入A1:B2,则对应合并 */
if
(
false
!==
strstr
(
$sKey
,
":"
))
{
$options
[
'mergeCells'
][
$sKey
]
=
$sKey
;
}
}
unset
(
$datas
);
/* 设置锁定行 */
if
(
isset
(
$options
[
'freezePane'
])
&&
!
empty
(
$options
[
'freezePane'
]))
{
$activeSheet
->
freezePane
(
$options
[
'freezePane'
]);
unset
(
$options
[
'freezePane'
]);
}
/* 设置宽度 */
if
(
isset
(
$options
[
'setWidth'
])
&&
!
empty
(
$options
[
'setWidth'
]))
{
foreach
(
$options
[
'setWidth'
]
as
$swKey
=>
$swItem
)
{
$activeSheet
->
getColumnDimension
(
$swKey
)
->
setWidth
(
$swItem
);
}
unset
(
$options
[
'setWidth'
]);
}
/* 设置背景色 */
if
(
isset
(
$options
[
'setARGB'
])
&&
!
empty
(
$options
[
'setARGB'
]))
{
foreach
(
$options
[
'setARGB'
]
as
$sItem
)
{
$activeSheet
->
getStyle
(
$sItem
)
->
getFill
()
->
setFillType
(
Fill
::
FILL_SOLID
)
->
getStartColor
()
->
setARGB
(
Color
::
COLOR_YELLOW
);
}
unset
(
$options
[
'setARGB'
]);
}
/* 设置公式 */
if
(
isset
(
$options
[
'formula'
])
&&
!
empty
(
$options
[
'formula'
]))
{
foreach
(
$options
[
'formula'
]
as
$fKey
=>
$fItem
)
{
$activeSheet
->
setCellValue
(
$fKey
,
$fItem
);
}
unset
(
$options
[
'formula'
]);
}
/* 合并行列处理 */
if
(
isset
(
$options
[
'mergeCells'
])
&&
!
empty
(
$options
[
'mergeCells'
]))
{
$activeSheet
->
setMergeCells
(
$options
[
'mergeCells'
]);
unset
(
$options
[
'mergeCells'
]);
}
/* 设置居中 */
if
(
isset
(
$options
[
'alignCenter'
])
&&
!
empty
(
$options
[
'alignCenter'
]))
{
$styleArray
=
[
'alignment'
=>
[
'horizontal'
=>
Alignment
::
HORIZONTAL_CENTER
,
'vertical'
=>
Alignment
::
VERTICAL_CENTER
,
],
];
foreach
(
$options
[
'alignCenter'
]
as
$acItem
)
{
$activeSheet
->
getStyle
(
$acItem
)
->
applyFromArray
(
$styleArray
);
}
unset
(
$options
[
'alignCenter'
]);
}
/* 设置加粗 */
if
(
isset
(
$options
[
'bold'
])
&&
!
empty
(
$options
[
'bold'
]))
{
foreach
(
$options
[
'bold'
]
as
$bItem
)
{
$activeSheet
->
getStyle
(
$bItem
)
->
getFont
()
->
setBold
(
true
);
}
unset
(
$options
[
'bold'
]);
}
/* 设置单元格边框,整个表格设置即可,必须在数据填充后才可以获取到最大行列 */
if
(
isset
(
$options
[
'setBorder'
])
&&
$options
[
'setBorder'
])
{
$border
=
[
'borders'
=>
[
'allBorders'
=>
[
'borderStyle'
=>
Border
::
BORDER_THIN
,
// 设置border样式
'color'
=>
[
'argb'
=>
'FF000000'
],
// 设置border颜色
],
],
];
$setBorder
=
'A1:'
.
$activeSheet
->
getHighestColumn
()
.
$activeSheet
->
getHighestRow
();
$activeSheet
->
getStyle
(
$setBorder
)
->
applyFromArray
(
$border
);
unset
(
$options
[
'setBorder'
]);
}
$fileName
=
!
empty
(
$fileName
)
?
$fileName
:
(
date
(
'YmdHis'
)
.
'.xlsx'
);
if
(
!
isset
(
$options
[
'savePath'
]))
{
/* 直接导出Excel,无需保存到本地,输出07Excel文件 */
header
(
'Content-Type: application/vnd.openxmlformats-officedocument.spreadsheetml.sheet'
);
header
(
"Content-Disposition:attachment;filename="
.
iconv
(
"utf-8"
,
"GB2312//TRANSLIT"
,
$fileName
)
);
header
(
'Cache-Control: max-age=0'
);
//禁止缓存
$savePath
=
'php://output'
;
}
else
{
$savePath
=
$options
[
'savePath'
];
}
ob_clean
();
ob_start
();
$objWriter
=
IOFactory
::
createWriter
(
$objSpreadsheet
,
'Xlsx'
);
$objWriter
->
save
(
$savePath
);
/* 释放内存 */
$objSpreadsheet
->
disconnectWorksheets
();
unset
(
$objSpreadsheet
);
ob_end_flush
();
return
true
;
}
catch
(
Exception
$e
)
{
return
false
;
}
}
public
function
export
(
$data
,
$name
){
ini_set
(
'memory_limit'
,
'1000M'
);
$spreadsheet
=
new
Spreadsheet
();
$sheet
=
$spreadsheet
->
getActiveSheet
();
// $sheet->setCellValue('A1','station_name 基站名称');
// $sheet->setCellValue('B1','station_sp_code 基站编号');
// $sheet->setCellValue('C1','proj_number 项目编号');
// $sheet->setCellValue('D1','number 编号');
// $sheet->setCellValue('E1','emt_id 类型');
// $sheet->setCellValue('F1','pay_number 缴费号');
// $sheet->setCellValue('G1','multiple 倍率');
// $sheet->setCellValue('H1','pay_cycle 交费周期');
// $sheet->setCellValue('I1','unit_price 电表单价');
// $sheet->setCellValue('J1','protocol_price 协议单价');
// $sheet->setCellValue('K1','address 电表地址 地址');
// $sheet->setCellValue('L1','remark 备注');
// $sheet->setCellValue('M1','create_time 创建时');
// $sheet->setCellValue('N1','init_degree 初始度数');
// $sheet->setCellValue('O1','first_cp_date 第一次抄表日期');
// $sheet->setCellValue('P1','is_protocol 是否是协议价');
// $sheet->setCellValue('Q1','staff_name 员工姓名');
// $sheet->setCellValue('R1','er_name 机房名称');
// $sheet->setCellValue('S1','er_position 机房位置');
// $sheet->setCellValue('T1','qrcode 二维码');
// $sheet->setCellValue('U1','er_contact 联系人');
// $sheet->setCellValue('V1','er_tel 联系电话');
// $sheet->setCellValue('W1','property_position 物业位置');
// $sheet->setCellValue('X1','receive 实际收款单位');
// $sheet->setCellValue('Y1','rent 出租单位');
// $sheet->setCellValue('Z1','er_remark 机房备注');
// $sheet->setCellValue('AA1','contract_number 合同编号');
// $sheet->setCellValue('AB1','contract_sign_time 合同开始时间');
// $sheet->setCellValue('AC1','period 合同周期');
// $sheet->setCellValue('AD1','protocol_name 协议名称');
// $sheet->setCellValue('AE1','protocol_number 协议编号');
// $sheet->setCellValue('AF1','protocol_sign_date 协议签订时间');
// $sheet->setCellValue('AG1','protocol_start_date 协议开始时间');
// $sheet->setCellValue('AH1','protocol_end_date 协议结束时间');
// $sheet->setCellValue('AI1','protocol_remark 协议备注');
// $sheet->setCellValue('AJ1','init_amount 初始电表额度');
// $sheet->setCellValue('AK1','qrcode 二维码');
$sheet
->
setCellValue
(
'A1'
,
'基站名称'
);
$sheet
->
setCellValue
(
'B1'
,
'基站编号'
);
$sheet
->
setCellValue
(
'C1'
,
'项目编号'
);
$sheet
->
setCellValue
(
'D1'
,
'表号'
);
$sheet
->
setCellValue
(
'E1'
,
'二维码'
);
$sheet
->
setCellValue
(
'F1'
,
'类型'
);
$sheet
->
setCellValue
(
'G1'
,
'缴费号'
);
$sheet
->
setCellValue
(
'H1'
,
'倍率'
);
$sheet
->
setCellValue
(
'I1'
,
'交费周期'
);
$sheet
->
setCellValue
(
'J1'
,
'电表单价'
);
$sheet
->
setCellValue
(
'K1'
,
'协议单价'
);
$sheet
->
setCellValue
(
'L1'
,
'电表地址'
);
$sheet
->
setCellValue
(
'M1'
,
'备注'
);
$sheet
->
setCellValue
(
'N1'
,
'创建时'
);
$sheet
->
setCellValue
(
'O1'
,
'初始度数'
);
$sheet
->
setCellValue
(
'P1'
,
'第一次抄表日期'
);
$sheet
->
setCellValue
(
'Q1'
,
'是否是协议价'
);
$sheet
->
setCellValue
(
'R1'
,
'员工姓名'
);
$sheet
->
setCellValue
(
'S1'
,
'机房名称'
);
$sheet
->
setCellValue
(
'T1'
,
'机房位置'
);
$sheet
->
setCellValue
(
'U1'
,
'二维码'
);
$sheet
->
setCellValue
(
'V1'
,
'联系人'
);
$sheet
->
setCellValue
(
'W1'
,
'联系电话'
);
$sheet
->
setCellValue
(
'X1'
,
'物业位置'
);
$sheet
->
setCellValue
(
'Y1'
,
'实际收款单位'
);
$sheet
->
setCellValue
(
'Z1'
,
'出租单位'
);
$sheet
->
setCellValue
(
'AA1'
,
'机房备注'
);
$sheet
->
setCellValue
(
'AB1'
,
'合同编号'
);
$sheet
->
setCellValue
(
'AC1'
,
'合同开始时间'
);
$sheet
->
setCellValue
(
'AD1'
,
'合同周期'
);
$sheet
->
setCellValue
(
'AE1'
,
'协议名称'
);
$sheet
->
setCellValue
(
'AF1'
,
'协议编号'
);
$sheet
->
setCellValue
(
'AG1'
,
'协议签订时间'
);
$sheet
->
setCellValue
(
'AH1'
,
'协议开始时间'
);
$sheet
->
setCellValue
(
'AI1'
,
'协议结束时间'
);
$sheet
->
setCellValue
(
'AJ1'
,
'协议备注'
);
$sheet
->
setCellValue
(
'AK1'
,
'初始电表额度'
);
$sheet
->
setCellValue
(
'AL1'
,
'二维码'
);
for
(
$i
=
0
;
$i
<
count
(
$data
);
$i
++
)
{
$sheet
->
setCellValue
(
'A'
.
(
$i
+
2
),
$data
[
$i
][
'station_name'
]);
$sheet
->
setCellValue
(
'B'
.
(
$i
+
2
),
$data
[
$i
][
'station_sp_code'
]);
$sheet
->
setCellValue
(
'C'
.
(
$i
+
2
),
$data
[
$i
][
'proj_number'
]);
$sheet
->
setCellValue
(
'D'
.
(
$i
+
2
),
$data
[
$i
][
'number'
]);
$sheet
->
setCellValue
(
'E'
.
(
$i
+
2
),
$data
[
$i
][
'qrcode'
]);
$sheet
->
setCellValue
(
'F'
.
(
$i
+
2
),
$data
[
$i
][
'emt_name'
]);
$sheet
->
setCellValue
(
'G'
.
(
$i
+
2
),
$data
[
$i
][
'pay_number'
]);
$sheet
->
setCellValue
(
'H'
.
(
$i
+
2
),
$data
[
$i
][
'multiple'
]);
$sheet
->
setCellValue
(
'I'
.
(
$i
+
2
),
$data
[
$i
][
'pay_cycle'
]);
$sheet
->
setCellValue
(
'J'
.
(
$i
+
2
),
$data
[
$i
][
'unit_price'
]);
$sheet
->
setCellValue
(
'K'
.
(
$i
+
2
),
$data
[
$i
][
'protocol_price'
]);
$sheet
->
setCellValue
(
'L'
.
(
$i
+
2
),
$data
[
$i
][
'address'
]);
$sheet
->
setCellValue
(
'M'
.
(
$i
+
2
),
$data
[
$i
][
'remark'
]);
$sheet
->
setCellValue
(
'N'
.
(
$i
+
2
),
$data
[
$i
][
'create_time'
]);
$sheet
->
setCellValue
(
'O'
.
(
$i
+
2
),
$data
[
$i
][
'init_degree'
]);
$sheet
->
setCellValue
(
'P'
.
(
$i
+
2
),
$data
[
$i
][
'first_cp_date'
]);
$sheet
->
setCellValue
(
'Q'
.
(
$i
+
2
),
$data
[
$i
][
'isprotocol'
]);
$sheet
->
setCellValue
(
'R'
.
(
$i
+
2
),
$data
[
$i
][
'staff_name'
]);
$sheet
->
setCellValue
(
'S'
.
(
$i
+
2
),
$data
[
$i
][
'er_name'
]);
$sheet
->
setCellValue
(
'T'
.
(
$i
+
2
),
$data
[
$i
][
'er_position'
]);
$sheet
->
setCellValue
(
'U'
.
(
$i
+
2
),
$data
[
$i
][
'qrcode'
]);
$sheet
->
setCellValue
(
'V'
.
(
$i
+
2
),
$data
[
$i
][
'er_contact'
]);
$sheet
->
setCellValue
(
'W'
.
(
$i
+
2
),
$data
[
$i
][
'er_tel'
]);
$sheet
->
setCellValue
(
'X'
.
(
$i
+
2
),
$data
[
$i
][
'property_position'
]);
$sheet
->
setCellValue
(
'Y'
.
(
$i
+
2
),
$data
[
$i
][
'receive'
]);
$sheet
->
setCellValue
(
'Z'
.
(
$i
+
2
),
$data
[
$i
][
'rent'
]);
$sheet
->
setCellValue
(
'AA'
.
(
$i
+
2
),
$data
[
$i
][
'er_remark'
]);
$sheet
->
setCellValue
(
'AB'
.
(
$i
+
2
),
$data
[
$i
][
'contract_number'
]);
$sheet
->
setCellValue
(
'AC'
.
(
$i
+
2
),
$data
[
$i
][
'contract_sign_time'
]);
$sheet
->
setCellValue
(
'AD'
.
(
$i
+
2
),
$data
[
$i
][
'period'
]
.
'月'
);
$sheet
->
setCellValue
(
'AE'
.
(
$i
+
2
),
$data
[
$i
][
'protocol_name'
]);
$sheet
->
setCellValue
(
'AF'
.
(
$i
+
2
),
$data
[
$i
][
'protocol_number'
]);
$sheet
->
setCellValue
(
'AG'
.
(
$i
+
2
),
$data
[
$i
][
'protocol_sign_date'
]);
$sheet
->
setCellValue
(
'AH'
.
(
$i
+
2
),
$data
[
$i
][
'protocol_start_date'
]);
$sheet
->
setCellValue
(
'AI'
.
(
$i
+
2
),
$data
[
$i
][
'protocol_end_date'
]);
$sheet
->
setCellValue
(
'AJ'
.
(
$i
+
2
),
$data
[
$i
][
'protocol_remark'
]);
$sheet
->
setCellValue
(
'AK'
.
(
$i
+
2
),
$data
[
$i
][
'init_amount'
]);
}
header
(
'Content-Type: application/vnd.ms-excel'
);
header
(
'Content-Disposition: attachment;filename="'
.
$name
.
'.xlsx"'
);
header
(
'Cache-Control: max-age=0'
);
$writer
=
new
\PhpOffice\PhpSpreadsheet\Writer\Xlsx
(
$spreadsheet
);
ob_end_clean
();
$writer
->
save
(
'php://output'
);
exit
;
}
public
function
baseexport
(
$data
,
$name
){
ini_set
(
'memory_limit'
,
'1000M'
);
$spreadsheet
=
new
Spreadsheet
();
$sheet
=
$spreadsheet
->
getActiveSheet
();
$sheet
->
setCellValue
(
'A1'
,
'基站名称 station_name'
);
$sheet
->
setCellValue
(
'B1'
,
'基站编号 station_sp_code'
);
$sheet
->
setCellValue
(
'C1'
,
'运营商 operator_name'
);
$sheet
->
setCellValue
(
'D1'
,
'需求号 sp_req_code'
);
$sheet
->
setCellValue
(
'E1'
,
'基站状态 cate_name'
);
$sheet
->
setCellValue
(
'F1'
,
'需求来源 sources_name'
);
$sheet
->
setCellValue
(
'G1'
,
'上游客户 customers_name'
);
$sheet
->
setCellValue
(
'H1'
,
'项目编号 proj_number'
);
$sheet
->
setCellValue
(
'I1'
,
'经度 longitude'
);
$sheet
->
setCellValue
(
'J1'
,
'纬度 latitude'
);
$sheet
->
setCellValue
(
'K1'
,
'业务线 business_name'
);
$sheet
->
setCellValue
(
'L1'
,
'区域 region_name'
);
$sheet
->
setCellValue
(
'M1'
,
'项目地址 location'
);
$sheet
->
setCellValue
(
'N1'
,
'墙面天线数 antenna_number'
);
$sheet
->
setCellValue
(
'O1'
,
'杆数 rod_number'
);
$sheet
->
setCellValue
(
'P1'
,
'箱体数 box_number'
);
$sheet
->
setCellValue
(
'Q1'
,
'RRU数量 rru_number'
);
$sheet
->
setCellValue
(
'R1'
,
'RRU方位角 rru_zimuth'
);
$sheet
->
setCellValue
(
'S1'
,
'光缆公里数 optical_cable'
);
$sheet
->
setCellValue
(
'T1'
,
'施工队类型 type'
);
$sheet
->
setCellValue
(
'U1'
,
'施工联系方式 construction_number'
);
$sheet
->
setCellValue
(
'V1'
,
'部门 name'
);
$sheet
->
setCellValue
(
'W1'
,
'经理 three_level_manager'
);
$sheet
->
setCellValue
(
'X1'
,
'业务员 salesman'
);
for
(
$i
=
0
;
$i
<
count
(
$data
);
$i
++
)
{
$sheet
->
setCellValue
(
'A'
.
(
$i
+
2
),
$data
[
$i
][
'station_name'
]);
$sheet
->
setCellValue
(
'B'
.
(
$i
+
2
),
$data
[
$i
][
'station_sp_code'
]);
$sheet
->
setCellValue
(
'C'
.
(
$i
+
2
),
$data
[
$i
][
'operator_name'
]);
$sheet
->
setCellValue
(
'D'
.
(
$i
+
2
),
$data
[
$i
][
'sp_req_code'
]);
$sheet
->
setCellValue
(
'E'
.
(
$i
+
2
),
$data
[
$i
][
'cate_name'
]);
$sheet
->
setCellValue
(
'F'
.
(
$i
+
2
),
$data
[
$i
][
'sources_name'
]);
$sheet
->
setCellValue
(
'G'
.
(
$i
+
2
),
$data
[
$i
][
'customers_name'
]);
$sheet
->
setCellValue
(
'H'
.
(
$i
+
2
),
$data
[
$i
][
'proj_number'
]);
$sheet
->
setCellValue
(
'I'
.
(
$i
+
2
),
$data
[
$i
][
'longitude'
]);
$sheet
->
setCellValue
(
'J'
.
(
$i
+
2
),
$data
[
$i
][
'latitude'
]);
$sheet
->
setCellValue
(
'K'
.
(
$i
+
2
),
$data
[
$i
][
'business_name'
]);
$sheet
->
setCellValue
(
'L'
.
(
$i
+
2
),
$data
[
$i
][
'region_name'
]);
$sheet
->
setCellValue
(
'M'
.
(
$i
+
2
),
$data
[
$i
][
'location'
]);
$sheet
->
setCellValue
(
'N'
.
(
$i
+
2
),
$data
[
$i
][
'antenna_number'
]);
$sheet
->
setCellValue
(
'O'
.
(
$i
+
2
),
$data
[
$i
][
'rod_number'
]);
$sheet
->
setCellValue
(
'P'
.
(
$i
+
2
),
$data
[
$i
][
'box_number'
]);
$sheet
->
setCellValue
(
'Q'
.
(
$i
+
2
),
$data
[
$i
][
'rru_number'
]);
$sheet
->
setCellValue
(
'R'
.
(
$i
+
2
),
$data
[
$i
][
'rru_zimuth'
]);
$sheet
->
setCellValue
(
'S'
.
(
$i
+
2
),
$data
[
$i
][
'optical_cable'
]);
$sheet
->
setCellValue
(
'T'
.
(
$i
+
2
),
$data
[
$i
][
'type'
]);
$sheet
->
setCellValue
(
'U'
.
(
$i
+
2
),
$data
[
$i
][
'construction_number'
]);
$sheet
->
setCellValue
(
'V'
.
(
$i
+
2
),
$data
[
$i
][
'name'
]);
$sheet
->
setCellValue
(
'W'
.
(
$i
+
2
),
$data
[
$i
][
'three_level_manager'
]);
$sheet
->
setCellValue
(
'X'
.
(
$i
+
2
),
$data
[
$i
][
'salesman'
]);
}
header
(
'Content-Type: application/vnd.ms-excel'
);
header
(
'Content-Disposition: attachment;filename="'
.
$name
.
'.xlsx"'
);
header
(
'Cache-Control: max-age=0'
);
$writer
=
new
\PhpOffice\PhpSpreadsheet\Writer\Xlsx
(
$spreadsheet
);
ob_end_clean
();
$writer
->
save
(
'php://output'
);
exit
;
}
public
function
meterexport
(
$data
,
$name
){
ini_set
(
'memory_limit'
,
'5000M'
);
$spreadsheet
=
new
Spreadsheet
();
$sheet
=
$spreadsheet
->
getActiveSheet
();
$sheet
->
setCellValue
(
'A1'
,
'支票号'
);
$sheet
->
setCellValue
(
'B1'
,
'缴费员'
);
$sheet
->
setCellValue
(
'C1'
,
'更新日期'
);
$sheet
->
setCellValue
(
'D1'
,
'项目编号'
);
$sheet
->
setCellValue
(
'E1'
,
'缴费号'
);
$sheet
->
setCellValue
(
'F1'
,
'电表数'
);
$sheet
->
setCellValue
(
'G1'
,
'缴费次数'
);
$sheet
->
setCellValue
(
'H1'
,
'和移动结算情况'
);
$sheet
->
setCellValue
(
'I1'
,
'基站类型'
);
$sheet
->
setCellValue
(
'J1'
,
'是否协议价'
);
$sheet
->
setCellValue
(
'K1'
,
'区域'
);
$sheet
->
setCellValue
(
'L1'
,
'网络标识'
);
$sheet
->
setCellValue
(
'M1'
,
'站号'
);
$sheet
->
setCellValue
(
'N1'
,
'站名'
);
$sheet
->
setCellValue
(
'O1'
,
'机房二维码'
);
$sheet
->
setCellValue
(
'P1'
,
'缴费周期'
);
$sheet
->
setCellValue
(
'Q1'
,
'预交费日期'
);
$sheet
->
setCellValue
(
'R1'
,
'上期表数'
);
$sheet
->
setCellValue
(
'S1'
,
'本期表数'
);
$sheet
->
setCellValue
(
'T1'
,
'实际报移动用电量'
);
$sheet
->
setCellValue
(
'U1'
,
'上期查表日期'
);
$sheet
->
setCellValue
(
'V1'
,
'本期查表日期'
);
$sheet
->
setCellValue
(
'W1'
,
'倍率'
);
$sheet
->
setCellValue
(
'X1'
,
'抄表单单价'
);
$sheet
->
setCellValue
(
'Y1'
,
'财务单价'
);
$sheet
->
setCellValue
(
'Z1'
,
'实际从财务支出金额'
);
$sheet
->
setCellValue
(
'AA1'
,
'用电量(1.05元/度)'
);
$sheet
->
setCellValue
(
'AB1'
,
'用电量(1.09元/度)'
);
$sheet
->
setCellValue
(
'AC1'
,
'用电量(1.123元/度)'
);
$sheet
->
setCellValue
(
'AD1'
,
'用电量(协议价)'
);
$sheet
->
setCellValue
(
'AE1'
,
'协议价'
);
$sheet
->
setCellValue
(
'AF1'
,
'移动结算金额'
);
$sheet
->
setCellValue
(
'AG1'
,
'回款次数'
);
$sheet
->
setCellValue
(
'AH1'
,
'毛利'
);
$sheet
->
setCellValue
(
'AI1'
,
'电表类型'
);
$sheet
->
setCellValue
(
'AJ1'
,
'电表识别号'
);
$sheet
->
setCellValue
(
'AK1'
,
'电表问题'
);
$sheet
->
setCellValue
(
'AL1'
,
'基站问题'
);
$sheet
->
setCellValue
(
'AM1'
,
'地址'
);
$sheet
->
setCellValue
(
'AN1'
,
'所属移动分公司'
);
$sheet
->
setCellValue
(
'AO1'
,
'出租单位名称'
);
$sheet
->
setCellValue
(
'AP1'
,
'甲方联系人'
);
$sheet
->
setCellValue
(
'AQ1'
,
'实际收款单位'
);
$sheet
->
setCellValue
(
'AR1'
,
'联系方式'
);
$sheet
->
setCellValue
(
'AS1'
,
'机房位置'
);
$sheet
->
setCellValue
(
'AT1'
,
'物业位置'
);
$sheet
->
setCellValue
(
'AU1'
,
'备注'
);
$sheet
->
setCellValue
(
'AV1'
,
'申请确认合同额'
);
$sheet
->
setCellValue
(
'AW1'
,
'结算日期'
);
$sheet
->
setCellValue
(
'AX1'
,
'确认合同时间'
);
$sheet
->
setCellValue
(
'AY1'
,
'确认收入时间'
);
$sheet
->
setCellValue
(
'AZ1'
,
'是否有发票'
);
$sheet
->
setCellValue
(
'BA1'
,
'合同编号'
);
$sheet
->
setCellValue
(
'BB1'
,
'发票类型'
);
$sheet
->
setCellValue
(
'BC1'
,
'税点'
);
for
(
$i
=
0
;
$i
<
count
(
$data
);
$i
++
)
{
$sheet
->
setCellValue
(
'A'
.
(
$i
+
2
),
$data
[
$i
][
'cheque_number'
]);
$sheet
->
setCellValue
(
'B'
.
(
$i
+
2
),
$data
[
$i
][
'payment_clerk'
]);
$sheet
->
setCellValue
(
'C'
.
(
$i
+
2
),
$data
[
$i
][
'update_time'
]);
$sheet
->
setCellValue
(
'D'
.
(
$i
+
2
),
$data
[
$i
][
'proj_number'
]);
$sheet
->
setCellValue
(
'E'
.
(
$i
+
2
),
$data
[
$i
][
'payment_number'
]);
$sheet
->
setCellValue
(
'F'
.
(
$i
+
2
),
$data
[
$i
][
'meters_number'
]);
$sheet
->
setCellValue
(
'G'
.
(
$i
+
2
),
$data
[
$i
][
'payments_umber'
]);
$sheet
->
setCellValue
(
'H'
.
(
$i
+
2
),
$data
[
$i
][
'settlement'
]);
$sheet
->
setCellValue
(
'I'
.
(
$i
+
2
),
$data
[
$i
][
'base_type'
]);
$sheet
->
setCellValue
(
'J'
.
(
$i
+
2
),
$data
[
$i
][
'is_protocol'
]);
$sheet
->
setCellValue
(
'K'
.
(
$i
+
2
),
$data
[
$i
][
'region'
]);
$sheet
->
setCellValue
(
'L'
.
(
$i
+
2
),
$data
[
$i
][
'network_identity'
]);
$sheet
->
setCellValue
(
'M'
.
(
$i
+
2
),
$data
[
$i
][
'station_number'
]);
$sheet
->
setCellValue
(
'N'
.
(
$i
+
2
),
$data
[
$i
][
'station_name'
]);
$sheet
->
setCellValue
(
'O'
.
(
$i
+
2
),
$data
[
$i
][
'qrcode'
]);
$sheet
->
setCellValue
(
'P'
.
(
$i
+
2
),
$data
[
$i
][
'payment_cycle'
]);
$sheet
->
setCellValue
(
'Q'
.
(
$i
+
2
),
$data
[
$i
][
'advance_pay_time'
]);
$sheet
->
setCellValue
(
'R'
.
(
$i
+
2
),
$data
[
$i
][
'last_number'
]);
$sheet
->
setCellValue
(
'S'
.
(
$i
+
2
),
$data
[
$i
][
'current_number'
]);
$sheet
->
setCellValue
(
'T'
.
(
$i
+
2
),
$data
[
$i
][
'report_electric'
]);
$sheet
->
setCellValue
(
'U'
.
(
$i
+
2
),
$data
[
$i
][
'last_date'
]);
$sheet
->
setCellValue
(
'V'
.
(
$i
+
2
),
$data
[
$i
][
'current_date'
]);
$sheet
->
setCellValue
(
'W'
.
(
$i
+
2
),
$data
[
$i
][
'multiple'
]);
$sheet
->
setCellValue
(
'X'
.
(
$i
+
2
),
$data
[
$i
][
'unit_price'
]);
$sheet
->
setCellValue
(
'Y'
.
(
$i
+
2
),
$data
[
$i
][
'finance_unit'
]);
$sheet
->
setCellValue
(
'Z'
.
(
$i
+
2
),
$data
[
$i
][
'finance_pay'
]);
$sheet
->
setCellValue
(
'AA'
.
(
$i
+
2
),
$data
[
$i
][
'electricone'
]);
$sheet
->
setCellValue
(
'AB'
.
(
$i
+
2
),
$data
[
$i
][
'electrictwo'
]);
$sheet
->
setCellValue
(
'AC'
.
(
$i
+
2
),
$data
[
$i
][
'electricthree'
]);
$sheet
->
setCellValue
(
'AD'
.
(
$i
+
2
),
$data
[
$i
][
'electricity_consumption'
]);
$sheet
->
setCellValue
(
'AE'
.
(
$i
+
2
),
$data
[
$i
][
'agreed_price'
]);
$sheet
->
setCellValue
(
'AF'
.
(
$i
+
2
),
$data
[
$i
][
'settlement_amount'
]);
$sheet
->
setCellValue
(
'AG'
.
(
$i
+
2
),
$data
[
$i
][
'back_number'
]);
$sheet
->
setCellValue
(
'AH'
.
(
$i
+
2
),
$data
[
$i
][
'gross_profit'
]);
$sheet
->
setCellValue
(
'AI'
.
(
$i
+
2
),
$data
[
$i
][
'meter_type'
]);
$sheet
->
setCellValue
(
'AJ'
.
(
$i
+
2
),
$data
[
$i
][
'meter_number'
]);
$sheet
->
setCellValue
(
'AK'
.
(
$i
+
2
),
$data
[
$i
][
'meter_problem'
]);
$sheet
->
setCellValue
(
'AL'
.
(
$i
+
2
),
$data
[
$i
][
'base_problem'
]);
$sheet
->
setCellValue
(
'AM'
.
(
$i
+
2
),
$data
[
$i
][
'address'
]);
$sheet
->
setCellValue
(
'AN'
.
(
$i
+
2
),
$data
[
$i
][
'subordinate'
]);
$sheet
->
setCellValue
(
'AO'
.
(
$i
+
2
),
$data
[
$i
][
'rental_name'
]);
$sheet
->
setCellValue
(
'AP'
.
(
$i
+
2
),
$data
[
$i
][
'contacts'
]);
$sheet
->
setCellValue
(
'AQ'
.
(
$i
+
2
),
$data
[
$i
][
'receiving_unit'
]);
$sheet
->
setCellValue
(
'AR'
.
(
$i
+
2
),
$data
[
$i
][
'contact_information'
]);
$sheet
->
setCellValue
(
'AS'
.
(
$i
+
2
),
$data
[
$i
][
'room_location'
]);
$sheet
->
setCellValue
(
'AT'
.
(
$i
+
2
),
$data
[
$i
][
'property_location'
]);
$sheet
->
setCellValue
(
'AU'
.
(
$i
+
2
),
$data
[
$i
][
'remarks'
]);
$sheet
->
setCellValue
(
'AV'
.
(
$i
+
2
),
$data
[
$i
][
'apply_contract_amount'
]);
$sheet
->
setCellValue
(
'AW'
.
(
$i
+
2
),
$data
[
$i
][
'settlement_date'
]);
$sheet
->
setCellValue
(
'AX'
.
(
$i
+
2
),
$data
[
$i
][
'confirmation_time'
]);
$sheet
->
setCellValue
(
'AY'
.
(
$i
+
2
),
$data
[
$i
][
'income_time'
]);
$sheet
->
setCellValue
(
'AZ'
.
(
$i
+
2
),
$data
[
$i
][
'is_invoice'
]);
$sheet
->
setCellValue
(
'BA'
.
(
$i
+
2
),
$data
[
$i
][
'contract_number'
]);
$sheet
->
setCellValue
(
'BB'
.
(
$i
+
2
),
$data
[
$i
][
'invoice_type'
]);
$sheet
->
setCellValue
(
'BC'
.
(
$i
+
2
),
$data
[
$i
][
'tax_point'
]);
}
header
(
'Content-Type: application/vnd.ms-excel'
);
header
(
'Content-Disposition: attachment;filename="'
.
$name
.
'.xls"'
);
header
(
'Cache-Control: max-age=0'
);
$writer
=
new
\PhpOffice\PhpSpreadsheet\Writer\Xlsx
(
$spreadsheet
);
ob_end_clean
();
$writer
->
save
(
'php://output'
);
exit
;
}
//基站流转数据信息导入
public
function
basestation_importExecl
(
string
$file
=
''
,
int
$sheet
=
0
,
int
$columnCnt
=
0
,
&
$options
=
[]){
ini_set
(
'memory_limit'
,
'1000M'
);
$extension
=
strtolower
(
pathinfo
(
$file
,
PATHINFO_EXTENSION
));
//判断导入表格后缀格式
// 有Xls和Xlsx格式两种
if
(
$extension
==
'xlsx'
)
{
$objReader
=
IOFactory
::
createReader
(
'Xlsx'
);
$objPHPExcel
=
$objReader
->
load
(
$file
);
}
elseif
(
$extension
==
'xls'
){
$objReader
=
IOFactory
::
createReader
(
'Xls'
);
$objPHPExcel
=
$objReader
->
load
(
$file
);
}
else
{
$this
->
error
(
'必须为excel表格,且必须为xls或者xlsx格式!'
);
}
//$filename可以是上传的表格,或者是指定的表格
$sheet
=
$objPHPExcel
->
getSheet
(
0
);
//excel中的第一张sheet
$highestRow
=
$sheet
->
getHighestRow
();
// 取得总行数
// $highestColumn = $sheet->getHighestColumn(); // 取得总列数
$error
=
0
;
for
(
$j
=
2
;
$j
<=
$highestRow
;
$j
++
)
{
$data
[
'jzProjectId'
]
=
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"A"
.
$j
)
->
getValue
();
$data
[
'jzRequire'
]
=
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"B"
.
$j
)
->
getValue
();
$data
[
'jzCode'
]
=
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"C"
.
$j
)
->
getValue
();
$data
[
'jzName'
]
=
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"D"
.
$j
)
->
getValue
();
$data
[
'projectCode'
]
=
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"E"
.
$j
)
->
getValue
();
$data
[
'jzType'
]
=
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"F"
.
$j
)
->
getValue
();
$data
[
'jzYys'
]
=
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"G"
.
$j
)
->
getValue
();
$data
[
'jzUpCustom'
]
=
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"H"
.
$j
)
->
getValue
();
$data
[
'businessLine'
]
=
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"I"
.
$j
)
->
getValue
();
$data
[
'jzQy'
]
=
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"J"
.
$j
)
->
getValue
();
$data
[
'projectAddress'
]
=
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"K"
.
$j
)
->
getValue
();
$data
[
'jzLongitude'
]
=
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"L"
.
$j
)
->
getValue
();
$data
[
'jzLatitude'
]
=
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"M"
.
$j
)
->
getValue
();
$data
[
'jzState'
]
=
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"N"
.
$j
)
->
getValue
();
$data
[
'jzCurDept'
]
=
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"O"
.
$j
)
->
getValue
();
$data
[
'jzProjectOwner'
]
=
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"P"
.
$j
)
->
getValue
();
$data
[
'jzCurUser'
]
=
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"Q"
.
$j
)
->
getValue
();
$data
[
'jzCreateDateStr'
]
=
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"R"
.
$j
)
->
getValue
();
$data
[
'jzEwm'
]
=
$objPHPExcel
->
getActiveSheet
()
->
getCell
(
"S"
.
$j
)
->
getValue
();
$url
=
'http://39.155.253.70:8081/jzmessage/KingDeeaddMessage'
;
$accessToken
=
$this
->
check_login
();
$jzdata
=
self
::
jz
(
$data
,
$url
,
$accessToken
);
dump
(
$jzdata
);
$jzdata
=
json_decode
(
$jzdata
,
true
);
if
(
$jzdata
[
'code'
]
!==
200
){
$error
++
;
}
}
// $datacount['total']=$highestRow-1;
// $datacount['suc']=$highestRow-1-$error;
// $datacount['er']=$error;
// return ['code' =>200,'message' => '导入成功' ,'data' => $datacount];
}
public
function
check_login
(){
$data
[
'password'
]
=
371
;
$data
[
'username'
]
=
371
;
$data
[
'userType'
]
=
1
;
$url
=
"http://39.155.253.70:8081/auth/login"
;
$token
=
self
::
jz
(
$data
,
$url
,
''
);
$token
=
json_decode
(
$token
,
true
);
if
(
$token
[
'code'
]
==
200
){
return
$token
[
'data'
];
}
}
static
function
jz
(
$jzdata
,
$url
,
$accessToken
){
if
(
$accessToken
){
$headers
[]
=
"Authorization: Bearer "
.
$accessToken
;
}
else
{
$headers
=
[];
}
$curl
=
curl_init
();
//设置抓取的url
curl_setopt
(
$curl
,
CURLOPT_URL
,
$url
);
//设置头文件的信息作为数据流输出
curl_setopt
(
$curl
,
CURLOPT_HEADER
,
0
);
//设置请求头
curl_setopt
(
$curl
,
CURLOPT_HTTPHEADER
,
$headers
);
//设置获取的信息以文件流的形式返回,而不是直接输出。
curl_setopt
(
$curl
,
CURLOPT_RETURNTRANSFER
,
1
);
//设置post方式提交
curl_setopt
(
$curl
,
CURLOPT_POST
,
1
);
//设置post数据
curl_setopt
(
$curl
,
CURLOPT_POSTFIELDS
,
$jzdata
);
//执行命令
$data
=
curl_exec
(
$curl
);
//关闭URL请求
curl_close
(
$curl
);
//显示获得的数据
return
$data
;
}
}
\ No newline at end of file
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论