### CSV 導入
jig 2018-1-30
**位置:**
Common\Tools\CsvTools.class.php
**參數:**
* @param $title array 標題
* @param $data array 數據
* @param $filename string 文件名
**調用:**
~~~
use Common\Tools\CsvTools; // 加載文件
public function import() {
$csv = new CsvTools(); // 實例化
$csv->csvImport(); // 導入操作
}
~~~
**完整代碼:**
~~~
/**
* 導入CSV 從BaseController import_csv 遷移過來
*
* jig 2017-11-30
* @param $column int 內容多少列
* @param $head 1 為1的時候輸出表頭
* @return array
*/
function csvImport ($column, $head = '') { // 文件路徑 文件內容
// setlocale(LC_ALL, 'zh_CN'); // linux 上中文亂碼 需要就打開
$flag = false;
$msg = '未處理';
$maxsize = 1 * 1024 * 1024; // 1MB
$max_column = 1000; // 最大條數
if (empty($column)) {
$msg = '列數不能為空';
$flag = true;
}
// 1、調用上傳類進行文件上傳
$upload = new UploadTools();
$info = $upload->saveFile(); // 上傳文件
if (!$info) {
$msg = $upload->getError();
$flag = true;
}
$path = APP_ROOT . $info['file_path']; // 文件上傳的路徑
// 2、檢測文件是否存在
if ($flag === false) {
if (!file_exists($path)) {
$msg = '文件不存在';
$flag = true;
}
}
// 3、檢測文件格式
if ($flag === false) {
if ($info['ext'] != 'csv') {
$msg = '只能導入CSV格式文件';
$flag = true;
}
}
// 4、檢測文件大小
if ($flag === false) {
if (filesize($path) > $maxsize) {
$msg = '導入的文件不得超過' . $maxsize . 'B文件';
$flag = true;
}
}
// 5、讀取文件
if ($flag === false) {
$row = 0;
$handle = fopen($path, 'r'); // 讀取文件
$result = array();
while ($data = fgetcsv($handle, $max_column, ",")) {
// 是否輸出表頭判斷
if ($head == 1) {
$row++;
}
// 基于表頭判斷表列是否一致
if ($row == 1) {
if (count($data) != $column) {
$msg = '文件不符合規范,請重新下載模版編輯數據';
$flag = true;
break;
}
}
/*
$num = count($data);
if ($num < $column) {
$msg = '文件不符合規格真實有:' . $num . '列數據';
$flag = true;
break;
}
*/
if ($flag === false) {
for ($i = 0; $i < $column; $i++) {
if ($row == 0) {
break; // 第一行標題不賦值
}
$result['data'][$row][$i] = mb_convert_encoding(trim($data[$i]), 'utf-8', 'gb2312 '); // trim($data[$i]); // 賦值組合數組
}
}
// 不輸出表頭格式
if ($head != 1) {
$row++;
}
}
}
$result['error'] = $flag;
if ($flag === true) {
$result['msg'] = $msg; // 提示錯誤信息判斷
}
return $result;
}
~~~
- 模版
- 前言
- 項目架構
- 項目規范
- HTML
- CSS
- Javascript
- PHP
- MySQL
- 注意規范
- 開發版本管理
- 開發流程
- 系統配置
- 阿里云服務器配置
- 計劃任務配置說明
- 開發示例
- Page分頁
- Search_param搜索結果賦值
- Add新增
- Edit編輯
- Ajax表單驗證
- Ajax二級聯動
- Excel 導出數據首位不去0的方法
- POS總部控制
- 下載CSV格式的模板
- 訂單唯一碼表和訂單SKU表實收金額生成
- 快捷日期選擇
- JS函數
- ajax_send
- ajax_result
- createQrCodes
- createBarCodes
- printTpl
- JS插件
- BootstrapValidator表單驗證插件
- Address省市區插件
- Bootstrap-datepicker日期插件
- Bootstrap-select多選框插件
- Toastr消息提示插件
- PalyAudit掃描聲音提示插件
- WebUploader多圖片上傳插件
- Ueditor富文本編輯器插件
- Function
- alert
- object_to_array
- array_to_object
- get_address
- set_param_url
- get_shops_name
- get_user_name
- get_warehouse
- get_cheapest_sku
- print_attr(新)
- print_img(新)
- get_spu_no(新)
- get_type_name(新)
- get_brand_en(新)
- get_cat_name(新)
- get_attr_name(新)
- spu_cat_info(新)
- get_time_event_price
- get_vendors
- check_total_reduce
- check_total_discount
- get_inventory
- get_delivery
- get_sale_inventory
- get_customer_name
- phone_protection
- get_order_no
- get_event_name
- get_order_status
- get_item_status
- get_ditch_name
- get_card_no
- get_shop_sales
- get_pay_name
- get_season
- amt_format
- get_cat_parent
- print_attr_id
- round_bcadd
- round_bcsub
- round_bcmul
- round_bcdiv
- get_account_name
- Controller
- Common_BaseController
- check_membership_card
- get_menu_list
- importErrorMassage
- Wpos_IndexController
- get_customer_vip_card
- get_shops_id
- calculate_active_integral
- check_numbers_active
- check_goods_active
- Woms_IndexController
- Model
- View
- category
- cycle_date.html
- shop_select門店多選搜索框
- 品牌A-Z排序多選brand_mc.html
- 供應商代碼A-Z排序vendor_no_mc.html
- Lib
- BuyerLib
- WarehouseLib
- EventLib
- getTimeEventPrice
- getVipType
- getEvent
- orderTotalEvent
- orderTimeEvent
- getTotalReduce
- getTotalDiscount
- SaleLib
- CustomerLib
- addCustomerService
- GiftcardLib
- WechatLib
- wxRefund
- OrdersLib
- orderLog
- calculatePayinAmount
- calculateSubtotal
- correctPayinAmount
- saveOrderAddress
- getOrderAddress
- setDeliveryNo
- SyncLib
- updateOuterStock
- UserLib
- createCommission
- FlowLib
- orderList
- addOrder
- addLog
- orderInfo
- checkSku
- orderSave
- orderStop
- orderExecute
- skuEdit
- orderPrinta
- scanGoods
- boxClose
- orderOut
- take
- bview
- check
- deliveryStatus
- checkGoods
- GoodsLib
- createGoodsNo
- createNewGoodsNo
- getSystemStyleNo
- getDim
- MallLib
- smsLog
- GoodsBaseLib
- getBrandInfo
- getBrandsInfo
- getAttrIdArray
- getPrintAttr
- getMustAttr
- getCatIdInfo
- valTypeId
- valsTypeId
- getCatNoInfo
- getCatInfo
- getAttrArr
- getAttrInfo
- getValInfo
- getAttrId
- getValId
- getAttrSeaon
- getValueId
- PointsLog
- pointsIn
- pointsUp
- EcGoodsLib
- getSkuInventory
- Tools
- CsvTools
- csvImport
- csvExport
- ExcelTools
- importExcel
- exportExcel
- exportHeadExcel
- MailTools
- SmsTools
- sendMessage
- UploadTools
- ExportTools
- exportData
- TaobaoTools
- getOnsaleItems
- getSkusItems
- PicturesTools
- uploadPicture
- Plugins
- WxBase
- Taobao
- 問題反饋