我們有一個名為student.csv的文件,里面包含有學(xué)生的學(xué)號、姓名、性別等信息,想要基于Python將CSV文件中的信息寫入MySQL數(shù)據(jù)庫的student_info表中。
下面給出具體實現(xiàn)代碼。
首先引入所需要的庫。
import pandas as pd
import pymysql
import csv
from collections import namedtuple
1、get_data函數(shù)打開文件csv文件, 通過open方法打開文件(python文件實現(xiàn)了迭代器協(xié)議),然后使用with語句來迭代讀取csv文件,然后存入命名元組,可以使用列名作為下標訪問元組中的內(nèi)容。
def get_data(file_name):
with open(file_name) as f:
f_csv = csv.reader(f)
headings = next(f_csv)
Row = namedtuple('Row', headings)
for r in f_csv:
yield Row(*r)
2、execute_sql,使用上下文管理器包裝execute執(zhí)行語句
def execute_sql(conn, sql):
with conn.cursor() as cur:
cur.execute(sql)
print('執(zhí)行成功')
3、main主函數(shù),連接數(shù)據(jù)庫,執(zhí)行SQL語句,提交commit,關(guān)閉連接。
def main()
conn = pymysql.connect(
host='xxx.xxx.xxx.xxx',
user='root',
passwd='密碼',
db='數(shù)據(jù)庫名稱',
port = 3306,
charset="utf8")
# 將CSV文件中的數(shù)據(jù)插入MySQL數(shù)據(jù)表中
SQL_FORMAT = """insert into student_info values('{0}', '{1}', '{2}')"""
conn.autocommit(1)
for t in get_data('./data/student.csv'):
print(t.id, t.name, t.gender)
sql = SQL_FORMAT.format(t.id, t.name, t.gender)
print(sql)
execute_sql(conn, sql)
conn.commit() # 提交到數(shù)據(jù)庫
conn.close() # 關(guān)閉數(shù)據(jù)庫服務(wù)
if __name__ == '__main__':
main()
執(zhí)行上述代碼,查看MySQL數(shù)據(jù)表中的內(nèi)容,發(fā)現(xiàn)數(shù)據(jù)被成功插入student_info 表中。
基于Python查詢MySQL數(shù)據(jù)表
conn = pymysql.connect(
host='xxx.xxx.xxx.xxx',
user='root',
passwd='密碼',
db='數(shù)據(jù)庫名稱',
port = 3306,
charset="utf8")
SQL_FORMAT = """select * from student_info where name='{0}'"""
sql_1 = SQL_FORMAT.format('Mary')
print('sql_1:', sql_1)
sql_2 = 'select * from student_info where name=%s'
print('sql_2:', sql_2)
with conn.cursor() as cur: # cursor對象用于執(zhí)行sql語句
cur.execute(sql_1)
res_1 = cur.fetchall() # 獲取結(jié)果及的所有數(shù)據(jù)
print('sql_1執(zhí)行結(jié)果:', res_1)
cur.execute(sql_2, 'Jack')
res_2 = cur.fetchall() # 獲取結(jié)果及的所有數(shù)據(jù)
print('sql_12執(zhí)行結(jié)果:', res_2)
conn.commit() # 提交
conn.close() # 關(guān)閉服務(wù)
輸出結(jié)果:文章來源:http://www.zghlxwxcb.cn/news/detail-508539.html
sql_1: select * from student_info where name='Mary'
sql_2: select * from student_info where name=%s
sql_1執(zhí)行結(jié)果: ((1, 'Mary', 'F'),)
sql_12執(zhí)行結(jié)果: ((2, 'Jack', 'M'),)
【參考博客】:文章來源地址http://www.zghlxwxcb.cn/news/detail-508539.html
- Python將csv文件導(dǎo)入到mysql數(shù)據(jù)庫
- Python寫入MySQL數(shù)據(jù)庫的三種方式詳解
到了這里,關(guān)于Python 將CSV文件數(shù)據(jù)存入Mysql數(shù)據(jù)庫的文章就介紹完了。如果您還想了解更多內(nèi)容,請在右上角搜索TOY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!