python 连接MySQL数据库 从文件中读取数据进行分块自动插入数据

automation_insert_into.py(自动插入数据)

  1. conn_mysql(host,port,user,passwd,db)
def conn_mysql(host='xxxxx',port=3306,user='xxx',passwd='xxxx',db='xxx'):
    '''
    mysql_ip_path:param host:
    mysql_port:param port:
    mysql_user:param user:
    mysql_passwd:param passwd:
    mysql_db:param db:
    mysql_conn:return:
    '''
    conn = pymysql.connect(
        host=host,
        port=port,
        user=user,
        passwd=passwd,
        db=db
    )
    return conn

  1. cut_data(file_path,cut_size=5)
def cut_data(file_path,cut_size=5):
    '''
    需要导入到数据库的文件:param file_path:
    将数据分多少块:param cut_size:
    分块后数据:return:
    '''
    all_data = []
    for i in range(cut_size):
        all_data.append([])
    with open(file_path,'r',encoding='utf-8')as f:
        lines = f.readlines()
        k = 1
        for i in lines:
            sub = k % cut_size
            data = i.replace('\n', '').split(',')
            data.insert(0, str(uuid.uuid1()).replace('-', ''))
            all_data[sub].append(tuple(data))

    return all_data
  1. insert_cut_data(conn,sql,cut_data)
def insert_cut_data(conn,sql,cut_data):
    '''
    mysql_conn:param conn:
    MySQL_statement:param sql:
    分块后的数据:param cut_data:
    None:return:
    '''
    cur = conn.cursor()
    for i in cut_data:
        cur.executemany(sql,i)
        conn.commit()
    cur.close()
    conn.close()
    print('数据导入成功!!!')

4.automation_insert_into.py

#coding:utf-8

import pymysql
import uuid

'''

__author__ == ForterJ
__date__ == 2019/4/3

'''
def conn_mysql(host='*',port='*',user='*',passwd='*',db='*'):
    '''
    mysql_ip_path:param host:
    mysql_port:param port:
    mysql_user:param user:
    mysql_passwd:param passwd:
    mysql_db:param db:
    mysql_conn:return:
    '''
    conn = pymysql.connect(
        host=host,
        port=port,
        user=user,
        passwd=passwd,
        db=db
    )
    return conn

def cut_data(file_path,cut_size=5):
    '''
    需要导入到数据库的文件:param file_path:
    将数据分多少块:param cut_size:
    分块后数据:return:
    '''
    all_data = []
    for i in range(cut_size):
        all_data.append([])
    with open(file_path,'r',encoding='utf-8')as f:
        lines = f.readlines()
        k = 1
        for i in lines:
            sub = k % cut_size
            data = i.replace('\n', '').split(',')
            data.insert(0, str(uuid.uuid1()).replace('-', ''))
            all_data[sub].append(tuple(data))

    return all_data

def insert_cut_data(conn,sql,cut_data):
    '''
    mysql_conn:param conn:
    MySQL_statement:param sql:
    分块后的数据:param cut_data:
    None:return:
    '''
    cur = conn.cursor()
    for i in cut_data:
        cur.executemany(sql,i)
        conn.commit()
    cur.close()
    conn.close()
    print('数据导入成功!!!')



你可能感兴趣的:(Python)