zoukankan      html  css  js  c++  java
  • 结合pandas,sqlite3批量将csv数据导入sqlite数据库

    import sqlite3
    import pandas as pd
    conn=sqlite3.connect(r'demo.db')
    c=conn.cursor()
    

    创建新表

    c.execute("""
    CREATE TABLE equipments (
    ID integer primary key autoincrement,
    设备状态 text,
    设备编码 text,
    设备名称 text,
    资产编码 text,
    所属科目 text,
    科目名称 text,
    规格型号 text,
    出厂日期 text,
    出厂编号 text,
    验收日期 text,
    初次调用 text,
    设备原值 text,
    借用人 text,
    借用办公室 text,
    借用科组 text,
    借用日期 text,
    借用凭证 text)
    """)
    

    现在有海量数据存储在csv上,如果我们选择也用python脚本将它批量写入db文件:

    s=pd.read_csv('file/demo.csv',encoding='gbk') # 有中文的要解码
    dataN,paraN=s.shape
    ques='('+'?,'*(paraN-1)+'?)' #cursor.execute中的动态参数表示
    for i in range(dataN):
        a=s.iloc[i].values
        b=a[1:]
        t=[int(a[0])]+a[1:]# a的第一个是ID,必须是integer类型,而pd读取的都是string,所以要进行转换
        c.execute('insert into equipments values '+ques,t)
        
    

    最后用HeidiSql查询,导入ok

    ****附:
    python sqlite3查看所有表名和表结构:
    select name from sqlite_master where type='table' order by name;

    ##### 愿你一寸一寸地攻城略地,一点一点地焕然一新 #####
  • 相关阅读:
    Deployment.yaml文件
    Python 闭包
    github使用方法(一)
    7.Python 正则表达式学习笔记
    kindle网络爬虫续集
    windows下如何快速搭建web.py开发框架
    Python强大的自省简析
    11--Python 备份文件程序
    10- python 网络爬虫分析
    Python基础学习7---异常处理
  • 原文地址:https://www.cnblogs.com/johnyang/p/13822003.html
Copyright © 2011-2022 走看看