您好,登錄后才能下訂單哦!
小編這次要給大家分享的是用代碼分析python中pymysql鏈接數(shù)據(jù)庫查詢結(jié)果如何轉(zhuǎn)為Dataframe,文章內(nèi)容豐富,感興趣的小伙伴可以來了解一下,希望大家閱讀完這篇文章之后能夠有所收獲。
我就廢話不多說了,大家還是直接看代碼吧!
import pymysql import pandas as pd def con_sql(db,sql): # 創(chuàng)建連接 db = pymysql.connect(host='127.0.0.1', port=3308, user='name', passwd='password', db=db, charset='utf8') # 創(chuàng)建游標(biāo) cursor = db.cursor() cursor.execute(sql) result = cursor.fetchall() #執(zhí)行結(jié)果轉(zhuǎn)化為dataframe df = pd.DataFrame(list(result)) # 關(guān)閉連接 db.close() #返回dataframe return df db = 'database' sql = 'select * from table' result = con_sql(db,sql) print(result.loc[2,2])#打?。?,3)位置的值)
其中,遍歷dataframe元素
import pandas as pd dict=[[1,2,3,4,5,6],[2,3,4,5,6,7],[3,4,5,6,7,8],[4,5,6,7,8,9],[5,6,7,8,9,10]] data=pd.DataFrame(dict) print(data) for indexs in data.index: print(data.loc[indexs].values[0:-1])
補(bǔ)充知識(shí):python 使用 pymssql 調(diào)用存儲(chǔ)過程并讓他返回值
眾所周知, pymssql 庫并不支持(暫時(shí)?)調(diào)用存儲(chǔ)過程,只能使用原生的sql 語句讓其調(diào)用。
這樣一來如果需要讓pymssql調(diào)用存儲(chǔ)過程并讓其返回值 , 顯然return語句是不能用了,
但是我們可以使用 select 語句讓其返回值。
比如,我想查詢數(shù)據(jù)是否插入成功,可以這樣寫
declare@oldCount int ; declare @newCount int ; ... if(@oldCount = @newCount) select -1; select1;
在python 中, 我們可以先調(diào)用存儲(chǔ)過程 [procInsert]
然后我們使用 fetchone 語句 即可得到大概的返回值,
因?yàn)榉祷刂档母袷绞?(-1,) 或者是 (1,) 這樣的。
這樣并不影響判斷, 但是強(qiáng)迫癥肯定受不了, 所以使用正則表達(dá)式提取制定的值即可.
看完這篇關(guān)于用代碼分析python中pymysql鏈接數(shù)據(jù)庫查詢結(jié)果如何轉(zhuǎn)為Dataframe的文章,如果覺得文章內(nèi)容寫得不錯(cuò)的話,可以把它分享出去給更多人看到。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。