国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Python > 正文

Python xlrd讀取excel日期類型的2種方法

2020-02-23 00:56:11
字體:
來源:轉載
供稿:網友

有個excle表格需要做一些過濾然后寫入數據庫中,但是日期類型的cell取出來是個數字,于是查詢了下解決的辦法。

基本的代碼結構
代碼如下:
data = xlrd.open_workbook(EXCEL_PATH) 
table = data.sheet_by_index(0) 
lines = table.nrows 
cols = table.ncols 
print u'The total line is %s, cols is %s'%(lines, cols) 

讀取某個單元格:
代碼如下:
table.cell(x, y).value 

x:行
y:列   
行,列都是從0開始

*  時間類型的轉換,把excel中時間轉成python 時間(兩種方式)
excel某個單元格   2014/7/8
代碼如下:
xlrd.xldate_as_tuple(table.cell(2,2).value, 0)   #轉化為元組形式 
(2014, 7, 8, 0, 0, 0) 
xlrd.xldate.xldate_as_datetime(table.cell(2,2).value, 1)   #直接轉化為datetime對象 
datetime.datetime(2018, 7, 9, 0, 0) 
table.cell(2,2).value   #沒有轉化 
41828.0 

源碼查看:
代碼如下:
# @param xldate The Excel number 
# @param datemode 0: 1900-based, 1: 1904-based. 
xldate_as_tuple(xldate, datemode)  

輸入一個日期類型的單元格會返回一個時間結構組成的元組,可以根據這個元組組成時間類型
datemode 有2個選項基本我們都會使用1900為基礎的時間戳

代碼如下:
## 
# Convert an Excel date/time number into a datetime.datetime object. 

# @param xldate The Excel number 
# @param datemode 0: 1900-based, 1: 1904-based. 

# @return a datetime.datetime() object. 

def xldate_as_datetime(xldate, datemode)

輸入參數和上面的相同,但是返回值是一個datetime類型,就不需要在自己轉換了

當然這兩個函數都有相應的逆函數,把python類型變成相應的excle時間類型。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 安吉县| 喀什市| 横峰县| 延庆县| 河津市| 云和县| 青铜峡市| 桂平市| 睢宁县| 随州市| 荣昌县| 白沙| 孝义市| 商水县| 垫江县| 维西| 克东县| 裕民县| 济阳县| 隆尧县| 万山特区| 湛江市| 桃园县| 高密市| 广汉市| 屯留县| 卢湾区| 即墨市| 渑池县| 紫阳县| 湾仔区| 华蓥市| 乌什县| 米易县| 博兴县| 怀仁县| 桦甸市| 保康县| 云安县| 冕宁县| 顺义区|