thinkphp导入csv文件代码
taotaoit ThinkPHP5.1 2025-05-13 23 0
关于本站

“最难不过坚持”

本人承接扒站仿站,php网站维护,病毒查杀,网站编辑,网站改版,html制作

有需要网站维护,改版,病毒查杀,网站编辑,网站备案,html制作等相关的工作可以联系我。
本人有多年相关工作经验,也可提供免费咨询,交个朋友。
有需要探讨问题的朋友,也可以加我微信,共同探讨!
微信:15011482830 QQ:408917339

8068719 2688 39
最新评论
https://jueru.net/
评 留言
:weixiao:
评 留言
:shuijiao: :weiqu: :zhenbang: :leng:
评 留言
:yiwen: :yiwen: :yiwen: :yiwen:
评 EasySass: could not generate CSS file. See Output panel for details.
这个业务逻辑多少都有点奇怪了,阅读浏览次数增值在新闻详情页的控制器方法里setInc,这怎么还写进模型事件里了。如果非要用onAfterRead也可以,把新闻文章的内容单独分出来一个news_content表,然后把它和news做关联,然后给news_content表的onAfterRead事件做增值处理,这样点进新闻页内查询到文章内容时才会触发它。
评 TP6模型事件-查询后onAfterRead不好用
文章标签更多
ThinkPHP (260)
Mysql (59)
DedeCms (33)
jQuery (74)
证件照 (1)
setInc (4)
setDec (4)
onclick (5)
打开边栏(ESC) 关闭边栏(ESC)

处理.csv文件成数组

public function importCsv($fileName, $line=0, $offset=0){
        $handle = fopen($fileName,'r');
        if(!$handle){
            return '文件打开失败';
        }
        $i = 0;
        $j = 0;
        $arr = [];
        while($data = fgetcsv($handle)){
            if($i < $offset && $offset){
                $i++;
                continue;
            }
            if($i > $line && $line){
                break;
            }
            foreach ($data as $key => $value) {
                $content = iconv("gbk","utf-8",$value);
                $arr[$j][] = $content;
            }
            $i++;
            $j++;
        }
        fclose($handle);
        return $arr;
    }
拼装数组

$filename = './static/upload/file/' . $f;
                $arr = $this->importCsv($filename, 0, 1);
                foreach($arr as $data){
                    $cards['orderNo'] = $data[0];
                    $cards['status'] = 0; // 导入都是0
                    $cards['subOrderNo'] = $data[3]; // 子订单编号
                    $cards['goodsName'] = $data[6]; // 商品名称
                    $cards['sku'] = $data[8]; // sku货号
                    $cards['skuid'] = $data[9];
                    $cards['goodsNum'] = $data[10];
                    $cards['name'] = $data[13];
                    $cards['phone'] = $data[19];
                    $cards['address'] = $data[20];
                    $cards['address2'] = $data[21];
                    $cards['address3'] = $data[22];
                    $cards['county'] = $data[23];
                    $cards['city'] = $data[24];
                    $cards['province'] = $data[25];
                    $cards['zip'] = $data[26];
                    $cards['national'] = $data[27];
                    $cards['orderTime'] = $data[28];
                    $cards['expressTime'] = $data[29];
                    $cards['email'] = $data[32];
                    $cards['bid'] = $bid;
                    $cards['aid'] = $aid;
                    $cards['createTime'] = date('Y-m-d H:i:s',time());

                    $orderNoSubOrderNo = $cards['orderNo'] . $cards['subOrderNo'];
                    if (in_array($orderNoSubOrderNo, $rsMap)) continue; // 如果打卡人打卡时间已存在,则跳出循环,执行下一次循环
                    $rsMap[] = $orderNoSubOrderNo;
                    $readData[] = $cards;
                    $cards = [];
                    $importNum++;
                }
添加到数据库

if (count($readData) > 0) {
                Db::table("m_daliy_report.d_order")->insertAll($readData);                
			}
每日报表导入订单用到

版权声明:本站原创文章,允许自由转载。

相关推荐
Non-static method think\Config::get() should not be called statically
ThinkPHP5.1 | 2018-12-29 11183
原来是这样use think\Config; 改成这样use think\facade\Config; 下面是官方手册的解释 配置获取 要使用Config类,首先需要在你的类文件中引入 use think\facade\Config; 或者(因为系统做了类库别名,其实就是调用think\facade\Config) u...
thinkPHP5 order多条件排序
ThinkPHP5.1 | 2017-10-24 11086
总结如下: //单一条件排序 $user = $this->where(['parentId'=>0)->field('userId,userName,userSort,isShow')->order('userSort', 'asc')->select(); //多个条件排序,可以多加一个order...
评论:0条
评论加载中...
发表评论