python 定义一个插入数据(可以插入到每个表中)通用的方法
生活随笔
收集整理的這篇文章主要介紹了
python 定义一个插入数据(可以插入到每个表中)通用的方法
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
前提置要:
想要寫一個方法,這個方法是插入數(shù)據(jù)到數(shù)據(jù)表的方法,只需要提供表名稱,字段名稱,還有插入的值,只要調(diào)用這個方法就可以自動幫助你插入數(shù)據(jù)
以下是不斷實踐優(yōu)化出來
原本的插入數(shù)據(jù)庫中的代碼應(yīng)該是這樣的:
insert into ty_test_info(name, age) VALUES ("wq",23)#*args的用法:當(dāng)傳入的參數(shù)個數(shù)未知,且不需要知道參數(shù)名稱時。在寫代碼之前就在想,有沒有一種參數(shù)(傳入的時候并不知道參數(shù)名稱),傳入?yún)?shù)的時候把所有表的字段名稱寫上,然后那邊可以返回一個元組,替代上面(name,age)的,還真的就有一個*key,這種參數(shù)可以傳入多個,然后返回的是一個元組
def test(a,b,c=3,*args):print(a)print(b)print(c)print(args) test(11,22,33,44,55)輸出的值為
11 22 33 (44,55)**kargs的用法:當(dāng)傳入的參數(shù)個數(shù)未知,但需要知道參數(shù)的名稱時(立馬想到了字典,即鍵值對)
''' 遇到問題沒人解答?小編創(chuàng)建了一個Python學(xué)習(xí)交流QQ群:778463939 尋找有志同道合的小伙伴,互幫互助,群里還有不錯的視頻學(xué)習(xí)教程和PDF電子書! ''' def test(**kwargs):print(kwargs)keys = kwargs.keys()value = kwargs.values()print(keys)print(value)test(a=1,b=2,c=3,d=4)# 輸出值分別為 # {'a': 1, 'b': 2, 'c': 3, 'd': 4} # dict_keys(['a', 'b', 'c', 'd']) # dict_values([1, 2, 3, 4])因為后面需要把要插入的數(shù)據(jù)寫出來(“wq”,23),那么怎么樣能夠顯示成這樣呢.
kwargs.values()把所有的value值讀取出來,先放到list里,然后把list轉(zhuǎn)換成tupple這樣就可以了
下面是這個方法:
def insertData(db,cursor,tablename,*key,**kwargs):# *key返回的是元組(),**返回的是字典values = []for value in kwargs.values():values.append(value)print(tuple(values))sql = 'insert into {} {}'.format(tablename,key).replace("'","")+' VALUES {}'.format(tuple(values))print(sql)try:cursor.execute(sql)db.commit()print("成功添加數(shù)據(jù)")print("插入數(shù)據(jù)的ID:",cursor.lastrowid)except Exception as e:print(e)# 發(fā)生錯誤時候回滾db.rollback() insertData(db,cur,"ty_test_info","name","age",name = "xw",age = 18)總結(jié)
以上是生活随笔為你收集整理的python 定义一个插入数据(可以插入到每个表中)通用的方法的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: python实现真正的冒泡排序算法(时间
- 下一篇: Python面试题 :计算列表中出现最多