python使用openpyxl實(shí)現(xiàn)對(duì)excel表格相對(duì)路徑的超鏈接的創(chuàng)建方式
使用openpyxl實(shí)現(xiàn)對(duì)excel表格相對(duì)路徑的超鏈接的創(chuàng)建
# 這個(gè)是相對(duì)路徑,可以修改父文件夾(images這個(gè)文件夾名不能更改) # img_path: images路徑下的圖片名 sheet.cell(row=img_site1_2 + 1, column=img_site2_2).hyperlink = 'images\\' + img_path
其他相關(guān)代碼
# 設(shè)置居中靠底部顯示
align2 = Alignment(horizontal='right', vertical='justify')
try:
# 使用tqdm庫(kù)進(jìn)行進(jìn)度條顯示
with tqdm(iterable=images, desc='圖片導(dǎo)入', unit='張', total=len(images)) as pgbr:
for img_path in images:
# 處理圖片名稱(獲取插入地址)
img_sites = img_path.split('_')
# 行數(shù)(需要+1)
img_site1 = int(img_sites[0])
img_site1_2 = img_site1
# sheet.row_dimensions[img_site1+1].height=40
img_site1 = str(img_site1+1)
# 轉(zhuǎn)換為int,方便使用這個(gè)值當(dāng)數(shù)組下標(biāo)去取clos的值,列數(shù)
img_site2 = int(img_sites[1])
# if img_site2 == 0:
# img_site2 = int(img_sites[2])
img_site2_2 = img_site2 + 11
# 數(shù)組取值從0開始,而獲取到的值是從1開始,真正的列值
img_site2 = cols[img_site2 - 1]
# 圖片真正的地址
img_path_real = savepath2 + '\\' + img_path
# 插入圖片本地地址
# 這個(gè)是絕對(duì)路徑(換一臺(tái)電腦就不好使了)
# file_name = 'file:///' + img_path_real # 這個(gè)是多余的,鏈接生成自動(dòng)會(huì)產(chǎn)生
# 使用相對(duì)路徑,換一臺(tái)電腦也可以正常訪問圖片)
sheet.column_dimensions[img_site2].width=18
# sh = sheet.row_dimensions[img_site1_2+1].height
# print("sh: ",sh)
# 插入到excel中的位置
position = img_site2 + img_site1
# 這個(gè)是絕對(duì)路徑,修改文件夾名稱就不能用了
# sheet.cell(row=img_site1_2 + 1, column=img_site2_2).hyperlink = img_path_real
# 這個(gè)是相對(duì)路徑,可以修改父文件夾(images這個(gè)文件夾名不能更改)
sheet.cell(row=img_site1_2 + 1, column=img_site2_2).hyperlink = 'images\\' + img_path
sheet.cell(row=img_site1_2 + 1, column=img_site2_2).style = "Hyperlink"
sheet.cell(row=img_site1_2 + 1, column=img_site2_2).value = '詳情'
sheet.cell(row=img_site1_2 + 1, column=img_site2_2).alignment = align2
# 可能存在插入的是視頻(視頻就直接以文件形式插入)
try:
img = Image(img_path_real)
img.width = 50
img.height = 50
# 插入圖片
sheet.add_image(img, position)
except Exception as e:
sheet.cell(row=img_site1_2 + 1, column=img_site2_2).value = '視頻' + str(img_site1_2) + '_' + str(img_site2_2 - 11)
sheet.cell(row=img_site1_2 + 1, column=img_site2_2).alignment = Alignment(horizontal='center', vertical='center')
# 進(jìn)度條
pgbr.update(1)
pass
path_filename2 = savepath + '\\' + 'xxx年xx月_' + '.xlsx'
wb.save(path_filename2)
except Exception as e:
print(e)
return e
openpyxl超鏈接添加
openpyxl的cell有屬性hyperlink屬性
這個(gè)屬性可以設(shè)置超鏈接,如果只是想設(shè)置一列有超鏈接,可以用if來設(shè)置
def write_to_execl_link(filename = './新建.xlsx',title='sheet',sheet_header = [],sheet_data = []):
import openpyxl
wb = openpyxl.Workbook()
ws = wb.active
ws.title = title
row0 = sheet_header
for i, r in enumerate(row0):
ws.cell(row=1, column=i + 1, value=r)
for i, r in enumerate(sheet_data):
for j, c in enumerate(r):
# if i%2 == 1:
# ws.cell(row=i + 2, column=j + 1).fill = fill
ws.cell(row=i + 2, column=j + 1, value=c)
ws.cell(row=i + 2, column=j + 1).hyperlink = r[-1]
wb.save(filename)openpyxl獲取文件內(nèi)容的超鏈接
import openpyxl import os #將Excel文件放在python同級(jí)目錄 dir_path = os.path.dirname(os.path.realpath(__file__)) test_xlsx = os.path.join(dir_path,f'''test.xlsx''') wb = openpyxl.load_workbook(test_xlsx) sheet = wb.active print(sheet.cell(1, 1).value) print(sheet.cell(1, 1).hyperlink.target)
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
- Python使用pandas和openpyxl讀取Excel表格的方法詳解
- python使用openpyxl打開及讀取excel表格過程
- python openpyxl提取Excel圖片實(shí)現(xiàn)原理技巧
- python?openpyxl操作Excel的安裝使用
- python使用openpyxl庫(kù)處理Excel文件詳細(xì)教程
- Python通過OpenPyXL處理Excel的完整教程
- python使用openpyxl庫(kù)讀取Excel文件數(shù)據(jù)
- python如何通過openpyxl讀寫Excel文件
- Python?Excel操作從零學(xué)習(xí)掌握openpyxl用法
- 使用python中的openpyxl操作excel詳解
- python操作Excel神器openpyxl看這一篇就夠了
- python使用Openpyxl操作Excel文件的實(shí)現(xiàn)
相關(guān)文章
用python實(shí)現(xiàn)操縱mysql數(shù)據(jù)庫(kù)插入
大家好,本篇文章主要講的是用python實(shí)現(xiàn)操縱mysql數(shù)據(jù)庫(kù)插入,感興趣的同學(xué)趕快來看一看吧,對(duì)你有幫助的話記得收藏一下2022-01-01
Tensorflow實(shí)現(xiàn)部分參數(shù)梯度更新操作
今天小編就為大家分享一篇Tensorflow實(shí)現(xiàn)部分參數(shù)梯度更新操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-01-01
python字符串拼接.join()和拆分.split()詳解
這篇文章主要為大家介紹了python字符串拼接.join()和拆分.split(),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助2021-11-11
python實(shí)現(xiàn)簡(jiǎn)單井字棋小游戲
這篇文章主要為大家詳細(xì)介紹了python實(shí)現(xiàn)簡(jiǎn)單井字棋小游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-03-03
利用Python通過獲取剪切板數(shù)據(jù)實(shí)現(xiàn)百度劃詞搜索功能
大家是不是嫌棄每次打開百度太麻煩?今天教大家利用Python通過獲取剪切板數(shù)據(jù)實(shí)現(xiàn)百度劃詞搜索功能,用程序直接打開網(wǎng)頁(yè),需要的朋友可以參考下2021-06-06
python繪圖時(shí),坐標(biāo)軸負(fù)號(hào)顯示不出來的解決
這篇文章主要介紹了python繪圖時(shí),坐標(biāo)軸負(fù)號(hào)顯示不出來的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-09-09
python實(shí)現(xiàn)nao機(jī)器人手臂動(dòng)作控制
這篇文章主要為大家詳細(xì)介紹了python實(shí)現(xiàn)nao機(jī)器人手臂動(dòng)作控制,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-04-04
python中?OpenCV和Pillow處理圖像操作及時(shí)間對(duì)比
這篇文章主要介紹了python中OpenCV和Pillow處理圖像操作及時(shí)間對(duì)比,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下2022-09-09

