91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Python讀取excel中的圖片完美解決方法

發布時間:2020-09-03 09:25:15 來源:腳本之家 閱讀:246 作者:瘦魚 欄目:開發技術

excel中有圖片是很常見的,但是通過python讀取excel中的圖片沒有很好的解決辦法。

網上找了一種很聰明的方法,原理是這樣的:

1、將待讀取的excel文件后綴名改成zip,變成壓縮文件。

2、再解壓這個文件。

3、在解壓后的文件夾中,就有excel中的圖片。

4、這樣讀excel中的圖片,就變成了讀文件夾中的圖片了,和普通文件一樣,可以做各種處理。

解壓后的壓縮包如下:

Python讀取excel中的圖片完美解決方法

python腳本如下:

 '''
 File Name:  readexcelimg
 Author:   tim
 Date:    2018/7/26 19:52
 Description: 讀取excel中的圖片,打印圖片路徑
   先將excel轉換成zip包,解壓zip包,包下面有文件夾存放了圖片,讀取這個圖片
 ''' 
 import os
 import zipfile
 # 判斷是否是文件和判斷文件是否存在
 def isfile_exist(file_path):
   if not os.path.isfile(file_path):
     print("It's not a file or no such file exist ! %s" % file_path)
     return False
   else:
     return True
 # 修改指定目錄下的文件類型名,將excel后綴名修改為.zip
 def change_file_name(file_path, new_type='.zip'):
   if not isfile_exist(file_path):
     return ''
   extend = os.path.splitext(file_path)[1] # 獲取文件拓展名
   if extend != '.xlsx' and extend != '.xls':
     print("It's not a excel file! %s" % file_path)
     return False
   file_name = os.path.basename(file_path) # 獲取文件名
   new_name = str(file_name.split('.')[0]) + new_type # 新的文件名,命名為:xxx.zip
   dir_path = os.path.dirname(file_path) # 獲取文件所在目錄
   new_path = os.path.join(dir_path, new_name) # 新的文件路徑
   if os.path.exists(new_path):
     os.remove(new_path)
   os.rename(file_path, new_path) # 保存新文件,舊文件會替換掉
   return new_path # 返回新的文件路徑,壓縮包
 # 解壓文件
 def unzip_file(zipfile_path):
   if not isfile_exist(zipfile_path):
     return False
   if os.path.splitext(zipfile_path)[1] != '.zip':
     print("It's not a zip file! %s" % zipfile_path)
     return False
   file_zip = zipfile.ZipFile(zipfile_path, 'r')
   file_name = os.path.basename(zipfile_path) # 獲取文件名
   zipdir = os.path.join(os.path.dirname(zipfile_path), str(file_name.split('.')[0])) # 獲取文件所在目錄
   for files in file_zip.namelist():
     file_zip.extract(files, os.path.join(zipfile_path, zipdir)) # 解壓到指定文件目錄
   file_zip.close()
   return True
 # 讀取解壓后的文件夾,打印圖片路徑
 def read_img(zipfile_path):
   if not isfile_exist(zipfile_path):
     return False
   dir_path = os.path.dirname(zipfile_path) # 獲取文件所在目錄
   file_name = os.path.basename(zipfile_path) # 獲取文件名
   pic_dir = 'xl' + os.sep + 'media' # excel變成壓縮包后,再解壓,圖片在media目錄
   pic_path = os.path.join(dir_path, str(file_name.split('.')[0]), pic_dir)
   file_list = os.listdir(pic_path)
   for file in file_list:
     filepath = os.path.join(pic_path, file)
     print(filepath)
 # 組合各個函數
 def compenent(excel_file_path):
   zip_file_path = change_file_name(excel_file_path)
   if zip_file_path != '':
     if unzip_file(zip_file_path):
       read_img(zip_file_path)
 # main
 if __name__ == '__main__':
   compenent('/Users/Desktop/test/people.xlsx')

總結

以上所述是小編給大家介紹的Python讀取excel中的圖片完美解決方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對億速云網站的支持!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

黔江区| 马尔康县| 县级市| 贺兰县| 南靖县| 通州市| 蓬溪县| 南部县| 徐闻县| 仁怀市| 云南省| 浮梁县| 利辛县| 海兴县| 沧源| 湘乡市| 宿州市| 明水县| 陵水| 会泽县| 杭锦后旗| 兴化市| 靖西县| 江源县| 合水县| 连平县| 娱乐| 龙南县| 呈贡县| 清徐县| 济南市| 大厂| 游戏| 金华市| 鄄城县| 楚雄市| 会东县| 灵武市| 托克逊县| 大竹县| 丹江口市|