欢迎来到php自学网~
阅读模式:

csv文件一键导入数据到mysql数据库

查看:2124  回复:0  类型:  来源:php自学网  标签 mysql php

        csv文件一键导入数据到mysql数据库的详细流程通过php中系统函数fgetcsv()一行行的去解析csv中的文件,并赋值给数组中,然后导入到数据库。

        fgetcsv('文件名','当前字段的字符串最大的长度')

        从文件指针中读入一行并解析 CSV 字段,如果读取错误或者到文件末尾返回FALSE。


示例代码:

<?php
    //解析csv函数,传入文件指针
    function input_csv($handle) {
        //定义数据数组
        $out = array ();
        //从一行中的第一列
        $n = 0;
        //进行数据遍历,如果这一行有数据就进行数据读取
        while ($data = fgetcsv($handle, 10000)) {
            //获取一行书中的总列数
            $num = count($data);
            //循环获取一行中的每个列的值并赋值给数据组
            for ($i = 0; $i < $num; $i++) {
                $out[$n][$i] = $data[$i];
            }
            $n++;
        }
        //返回所有读取到的数据数组
        return $out;
    }

    //接收通过form表单提交过来的文件
    $filename = $_FILES['file']['tmp_name'];
    //没有找到文件提示
    if (empty ($filename)) {
        echo '请选择要导入的CSV文件!';
    } else {
        //找到提交的文件进行提示
        echo '正在读取文件,请稍等...';
        //打开读取文件数据
        $handle = fopen($filename, 'r');
        //解析csv自定义的函数
        $result = input_csv($handle);
        //获取结果集数据数组文件总行数
        $len_result = count($result);

        if ($len_result == 0) {
            echo '没有任何数据!';
        } else {
            //循环获取各字段值
            for ($i = 1; $i < $len_result; $i++) {
                //赋值给变量,如果为中文必须进行转码成数据库一致的编码
                $name = iconv('gb2312', 'utf-8', $result[$i][1]);
                $num = $result[$i][2];
                $fid = $result[$i][3];
                $status = iconv('gb2312', 'utf-8', $result[$i][4]);
                $details = iconv('gb2312', 'utf-8', $result[$i][5]);
                $info = iconv('gb2312', 'utf-8', $result[$i][6]);

                //拼接数据的SQL语句
                $data_values .= "($status,'$name','$password','$authorize','$area','$province'),";

            }
            //去掉最后一个逗号
            $data_values = substr($data_values,0,-1);
            //关闭指针文件
            fclose($handle);
            //插入数据表中
            $sql = "insert into user(name,num,fid,status,details,info) values".$data_values;
            $query = $nsodb->query($sql);
            if ($query) {
                echo '导入成功!';
            } else {
                echo '导入失败!';
            }
        }
    }
?>


分享到:
0 0

*有问题之处烦请在评论中指出非常感谢!
不是我想要的内容,继续搜索:

扫描二维码手机查看

发布评论:


登录:
  表情:
评论话题
推荐阅读:
centos 7 开启网络   阅读:1646一键分享到QQ空间、QQ好友、新浪微博、微信代码   阅读:9777什么是天使轮?什么是A轮融资?B轮融资?   阅读:1112PHP 鸟哥:我也曾经是“不适合”编程的人   阅读:2668php 生成图片,给图片加水印   阅读:2279把php session 会话保存到redis   阅读:2252linux php7安装yaf扩展   阅读:1462php 获取当前前后年、月、星期、日、时分秒的时间   阅读:1912php压缩页面的html代码一行显示   阅读:2053centos 7 安装 redis 3.2.9   阅读:2479Mysql在大型网站的应用架构演变   阅读:1637centos7.3安装mongodb3.6   阅读:1997linux php7编译安装mongodb扩展   阅读:1467小米手机端商城rem适配原理   阅读:2892mysql共享锁和排他锁详解   阅读:1854mysql数据库性能的基本优化   阅读:1763centos 7 修改系统屏幕分辨率   阅读:15119比phpexcel还要简单的excel CSV 一键导入数据到数据库   阅读:1854网站局部小图片优化-base64编码图片   阅读:2580mysql中文分词全文搜索索引讯搜的安装   阅读:1733php显示刚刚、几分钟前、几小时前、几天前的函数   阅读:1993用php从1乘到100的值   阅读:2040一键分享到QQ空间、QQ好友、新浪微博、微信代码   阅读:9777centos 7 安装 nginx-1.11.10   阅读:3234php 统计网页打开耗时和脚本运行内存   阅读:2188php 读取和设置redis的键值   阅读:2714php中地址引用&的真正理解-变量引用、函数引用、对象引用   阅读:1489php显示刚刚、几分钟前、几小时前、几天前的函数   阅读:1993ajax+php 实现一个简单的在线聊天室功能(附带源码)   阅读:3070网站局部小图片优化-base64编码图片   阅读:2580给php7安装redis扩展库   阅读:2212linux php7编译安装mongodb扩展   阅读:1467小米手机端商城rem适配原理   阅读:2892爱编程,也爱健康   阅读:1054什么是天使轮?什么是A轮融资?B轮融资?   阅读:1112一键分享到QQ空间、QQ好友、新浪微博、微信代码   阅读:9777centos 7 设置 nginx-1.11.10 开机启动   阅读:2661php生成二维码   阅读:1870最新centos7 搭建LNMP环境(centos7.2+php7+mysql5.7+nginx1.11+redis3.2)   阅读:4017移动端自适应rem原理   阅读:4857linux php7编译安装mongodb扩展   阅读:1467十张GIF让你弄懂递归等概念   阅读:1710centos 7 安装 samba 服务   阅读:1674php设置cookie为HttpOnly防止XSS攻击   阅读:2518纯干货,程序员面试的超实用技巧   阅读:1288centos 7 安装 redis 3.2.9   阅读:2479phpexcel 超简单从excel表格一键导入数据到数据库教程   阅读:5117centos7开启交换内存   阅读:2445人性漫画:打工与创业的残酷区别   阅读:1361linux php7编译安装mongodb扩展   阅读:1467