python pymysql鏈接數(shù)據(jù)庫(kù)查詢結(jié)果轉(zhuǎn)為Dataframe實(shí)例
我就廢話不多說了,大家還是直接看代碼吧!
import pymysqlimport pandas as pddef 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 dfdb = ’database’sql = ’select * from table’result = con_sql(db,sql)print(result.loc[2,2])#打印(3,3)位置的值)
其中,遍歷dataframe元素
import pandas as pddict=[[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 庫(kù)并不支持(暫時(shí)?)調(diào)用存儲(chǔ)過程,只能使用原生的sql 語(yǔ)句讓其調(diào)用。
這樣一來(lái)如果需要讓pymssql調(diào)用存儲(chǔ)過程并讓其返回值 , 顯然return語(yǔ)句是不能用了,
但是我們可以使用 select 語(yǔ)句讓其返回值。
比如,我想查詢數(shù)據(jù)是否插入成功,可以這樣寫
declare@oldCount int ; declare @newCount int ; ... if(@oldCount = @newCount) select -1; select1;
在python 中, 我們可以先調(diào)用存儲(chǔ)過程 [procInsert]
然后我們使用 fetchone 語(yǔ)句 即可得到大概的返回值,
因?yàn)榉祷刂档母袷绞?(-1,) 或者是 (1,) 這樣的。
這樣并不影響判斷, 但是強(qiáng)迫癥肯定受不了, 所以使用正則表達(dá)式提取制定的值即可.
以上這篇python pymysql鏈接數(shù)據(jù)庫(kù)查詢結(jié)果轉(zhuǎn)為Dataframe實(shí)例就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. html小技巧之td,div標(biāo)簽里內(nèi)容不換行2. HTML DOM setInterval和clearInterval方法案例詳解3. ASP腳本組件實(shí)現(xiàn)服務(wù)器重啟4. webpack高級(jí)配置與優(yōu)化詳解5. HTML <!DOCTYPE> 標(biāo)簽6. CSS3中Transition屬性詳解以及示例分享7. 概述IE和SQL2k開發(fā)一個(gè)XML聊天程序8. XML入門的常見問題(一)9. chat.asp聊天程序的編寫方法10. ASP動(dòng)態(tài)網(wǎng)頁(yè)制作技術(shù)經(jīng)驗(yàn)分享
