python 讀取excel文件生成sql文件實例詳解
python 讀取excel文件生成sql文件實例詳解
學了python這么久,總算是在工作中用到一次。這次是為了從excel文件中讀取數(shù)據然后寫入到數(shù)據庫中。這個邏輯用java來寫的話就太重了,所以這次考慮通過python腳本來實現(xiàn)。
在此之前需要給python添加一個xlrd模塊,這個模塊是專門用來操作excel文件的。
在mac中可以通過easy_install xlrd命令實現(xiàn)自動安裝模塊
import xdrlib ,sys
import xlrd
def open_excel(file= a.xlsx'):
try:
data = xlrd.open_workbook(file)#打開excel文件
return data
except Exception,e:
print str(e)
def excel_table_bycol(file='a.xlsx',colindex=[0],table_name='Sheet1'):
data = open_excel(file)
table = data.sheet_by_name(table_name)#獲取excel里面的某一頁
nrows = table.nrows#獲取行數(shù)
colnames = table.row_values(0)#獲取第一行的值,作為key來使用,對于不同的excel文件可以進行調整
list = []
#(1,nrows)表示取第一行以后的行,因為第一行往往是表頭
for rownum in range(1,nrows):
row = table.row_values(rownum)
if row:
app = {}
for i in colindex:
app[str(colnames[i]).encode("utf-8")] = str(row[i]).encode("utf-8")#將數(shù)據填入一個字典中,同時對數(shù)據進行utf-8轉碼,因為有些數(shù)據是unicode編碼的
list.append(app)#將字典加入列表中去
return list
def main():
#colindex是一個數(shù)組,用來選擇讀取哪一列,因為往往excel中的一小部分才是我們需要的
tables = excel_table_bycol(colindex=[1,4],table_name=u'areaCode')
file = open('channel_area_code.sql','w')#創(chuàng)建sql文件,并開啟寫模式
for row in tables:
if row['area_code'] != '':
file.write("update table_name set para1='%s' where para2='%s';\n"%(row['para1'],row['para2']))#往文件里寫入sql語句
if __name__=="__main__":
main()
這并非是一個通用的python腳本,還是需要根據excel文件的格式作出一些調整,但是代碼并不復雜,開發(fā)速度也很快,比以前用java是輕松多了。
感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
相關文章
python中struct模塊之字節(jié)型數(shù)據的處理方法
今天小編就為大家分享一篇python中struct模塊之字節(jié)型數(shù)據的處理方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-08-08
Python搭建Keras CNN模型破解網站驗證碼的實現(xiàn)
這篇文章主要介紹了Python搭建Keras CNN模型破解網站驗證碼的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-04-04
Python Django模板之模板過濾器與自定義模板過濾器示例
這篇文章主要介紹了Python Django模板之模板過濾器與自定義模板過濾器,結合實例形式分析了Django框架模板過濾器與自定義模板過濾器相關功能、原理、使用方法及相關操作注意事項,需要的朋友可以參考下2019-10-10
Python使用Pandas對比兩列數(shù)據取最大值的五種方法
本文主要介紹使用 Pandas 對比兩列數(shù)據取最大值的五種方法,包括使用 max 方法、apply 方法結合 lambda 函數(shù)、函數(shù)、clip 方法、where 方法結合條件賦值,并通過案例進行詳細說明,需要的朋友可以參考下2025-02-02
Django?REST?Framework?(DRF)?項目中實現(xiàn)JWT的示例代碼
本文主要介紹了Django?REST?Framework?(DRF)?項目中實現(xiàn)JWT的示例代碼,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2025-02-02

