亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Python保存dict字典類型數(shù)據(jù)到Mysql并自動創(chuàng)建表與列

 更新時間:2022年02月11日 17:22:39   作者:呆萌的代Ma  
這篇文章主要介紹了Python保存dict字典類型數(shù)據(jù)到Mysql并自動創(chuàng)建表與列,字典是另一種可變?nèi)萜髂P停铱纱鎯θ我忸愋蛯ο?,想了解更多?nèi)容的小伙伴可以和小編一起進(jìn)入下面文章學(xué)習(xí)更多內(nèi)容,希望對你有所幫助

字典是另一種可變?nèi)萜髂P?,且可存儲任意類型對象,主要是工具類?/p>

接下來使用pymysql來創(chuàng)建表與SQL

下面來看看示例代碼:

import pymysql


class UseMysql(object):
? ? def __init__(self, user, passwd, db, host="127.0.0.1", port=3306):
? ? ? ? self.db = db
? ? ? ? self.conn = pymysql.connect(
? ? ? ? ? ? host=host, user=user, passwd=passwd, db=db, port=port, charset='utf8') ?# 鏈接數(shù)據(jù)庫
? ? ? ? self.cursor = self.conn.cursor()

? ? def table_exists(self, table_name) -> bool:
? ? ? ? """判斷表是否存在
? ? ? ? :param table_name: 表名
? ? ? ? :return: 存在返回True,不存在返回False
? ? ? ? """
? ? ? ? sql = "show tables;"
? ? ? ? self.cursor.execute(sql)
? ? ? ? tables = self.cursor.fetchall()
? ? ? ? for _t in tables:
? ? ? ? ? ? if table_name == _t[0]:
? ? ? ? ? ? ? ? return True
? ? ? ? return False

? ? def create_table(self, data: dict, table_name):
? ? ? ? """創(chuàng)建表"""
? ? ? ? # 構(gòu)造數(shù)據(jù)庫
? ? ? ? sql_key_str = ''
? ? ? ? columnStyle = ' text' ?# 數(shù)據(jù)庫字段類型
? ? ? ? for key in data.keys():
? ? ? ? ? ? sql_key_str = sql_key_str + ' ' + key + columnStyle + ','
? ? ? ? self.cursor.execute("CREATE TABLE %s (%s)" % (table_name, sql_key_str[:-1]))
? ? ? ? # 添加自增ID
? ? ? ? self.cursor.execute("""ALTER TABLE `{}` \
? ? ? ? ? ? ? ? ? ? ADD COLUMN `id` INT NOT NULL AUTO_INCREMENT FIRST, \
? ? ? ? ? ? ? ? ? ? ADD PRIMARY KEY (`id`);"""
? ? ? ? ? ? ? ? ? ? ? ? ? ? .format(table_name))
? ? ? ? # 添加創(chuàng)建時間
? ? ? ? self.cursor.execute(
? ? ? ? ? ? """ALTER TABLE {} ADD join_time timestamp NULL DEFAULT current_timestamp();""".format(table_name))

? ? def write_dict(self, data: dict, table_name):
? ? ? ? """
? ? ? ? 寫入mysql,如果沒有表,創(chuàng)建表
? ? ? ? :param data: 字典類型
? ? ? ? :param table_name: 表名
? ? ? ? :return:
? ? ? ? """
? ? ? ? if not self.table_exists(table_name):
? ? ? ? ? ? self.create_table(data, table_name)
? ? ? ? sql_key = '' ?# 數(shù)據(jù)庫行字段
? ? ? ? sql_value = '' ?# 數(shù)據(jù)庫值
? ? ? ? for key in data.keys(): ?# 生成insert插入語句
? ? ? ? ? ? sql_value = (sql_value + '"' + pymysql.escape_string(data[key]) + '"' + ',')
? ? ? ? ? ? sql_key = sql_key + ' ' + key + ','

? ? ? ? self.cursor.execute(
? ? ? ? ? ? "INSERT INTO %s (%s) VALUES (%s)" % (table_name, sql_key[:-1], sql_value[:-1]))
? ? ? ? self.conn.commit() ?# 提交當(dāng)前事務(wù)


if __name__ == '__main__':
? ? mysql = UseMysql('用戶名', '密碼', '數(shù)據(jù)庫名')
? ? my_data1 = {"col1": "a", "col2": "b", "col3": "c", }
? ? mysql.write_dict(my_data1, table_name="mytable")
? ? my_data2 = {"col1": "a2", "col2": "b2"}
? ? mysql.write_dict(my_data2, table_name="mytable")

到此這篇關(guān)于Python保存dict字典類型數(shù)據(jù)到Mysql并自動創(chuàng)建表與列的文章就介紹到這了,更多相關(guān)Python保存dict字典類型數(shù)據(jù)到Mysql并自動創(chuàng)建表與列內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • PyTorch dropout設(shè)置訓(xùn)練和測試模式的實現(xiàn)

    PyTorch dropout設(shè)置訓(xùn)練和測試模式的實現(xiàn)

    這篇文章主要介紹了PyTorch dropout設(shè)置訓(xùn)練和測試模式的實現(xiàn)方式,具有很好的參考價值,希望對大家有所幫助。
    2021-05-05
  • Tensorflow獲取張量Tensor的具體維數(shù)實例

    Tensorflow獲取張量Tensor的具體維數(shù)實例

    今天小編就為大家分享一篇Tensorflow獲取張量Tensor的具體維數(shù)實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-01-01
  • Python常用base64 md5 aes des crc32加密解密方法匯總

    Python常用base64 md5 aes des crc32加密解密方法匯總

    這篇文章主要介紹了Python常用base64 md5 aes des crc32加密解密方法匯總,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-11-11
  • 如何利用Python寫個坦克大戰(zhàn)

    如何利用Python寫個坦克大戰(zhàn)

    這篇文章主要給大家介紹了關(guān)于如何利用Python寫個坦克大戰(zhàn)的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-11-11
  • python將人民幣轉(zhuǎn)換大寫的腳本代碼

    python將人民幣轉(zhuǎn)換大寫的腳本代碼

    python將人民幣轉(zhuǎn)換大寫的代碼,有需要的朋友可以參考下
    2013-02-02
  • Python算法之圖的遍歷

    Python算法之圖的遍歷

    這篇文章主要介紹了Python算法之圖的遍歷,涉及遍歷算法BFS和DFS,以及尋找圖的(強(qiáng))連通分量的算法等相關(guān)內(nèi)容,具有一定參考價值,需要的朋友可以了解下。
    2017-11-11
  • python的多重繼承的理解

    python的多重繼承的理解

    這篇文章主要介紹了python的多重繼承的理解的相關(guān)資料,多重繼承不是多容易理解,這里舉例說明幫助大家學(xué)習(xí)參考,需要的朋友可以參考下
    2017-08-08
  • Python3實現(xiàn)的爬蟲爬取數(shù)據(jù)并存入mysql數(shù)據(jù)庫操作示例

    Python3實現(xiàn)的爬蟲爬取數(shù)據(jù)并存入mysql數(shù)據(jù)庫操作示例

    這篇文章主要介紹了Python3實現(xiàn)的爬蟲爬取數(shù)據(jù)并存入mysql數(shù)據(jù)庫操作,涉及Python正則爬取數(shù)據(jù)及針對mysql數(shù)據(jù)庫的存儲操作相關(guān)實現(xiàn)技巧,需要的朋友可以參考下
    2018-06-06
  • Python實現(xiàn)的批量修改文件后綴名操作示例

    Python實現(xiàn)的批量修改文件后綴名操作示例

    這篇文章主要介紹了Python實現(xiàn)的批量修改文件后綴名操作,涉及Python目錄文件的遍歷、重命名等相關(guān)操作技巧,需要的朋友可以參考下
    2018-12-12
  • django的settings中設(shè)置中文支持的實現(xiàn)

    django的settings中設(shè)置中文支持的實現(xiàn)

    這篇文章主要介紹了django的settings中設(shè)置中文支持的實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04

最新評論