婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 淺談openpyxl庫,遇到批量合并單元格的問題

淺談openpyxl庫,遇到批量合并單元格的問題

熱門標簽:汕頭電商外呼系統供應商 云南地圖標注 鄭州智能外呼系統中心 南京crm外呼系統排名 賓館能在百度地圖標注嗎 400電話 申請 條件 北京外呼電銷機器人招商 crm電銷機器人 電銷機器人 金倫通信

我就廢話不多說了,大家還是直接看代碼吧~

from openpyxl import Workbook
from openpyxl import load_workbook
from openpyxl.styles import NamedStyle, Border, Side, Alignment 
 
# 創建一個工作薄
wb = Workbook()
 
# 創建一個工作表(注意是一個屬性)
table = wb.active
 
# excel創建的工作表名默認為sheet1,一下代碼實現了給新創建的工作表創建一個新的名字
table.title = 'test'
 
# 合并C1 D1 
# 法一
# table.merge_cells('C1:D1')
# table.cell(row = 1,column = 3,value = 'pdf/mp3鏈接')
# 法二
table.merge_cells(start_row=1, start_column=3, end_row=1, end_column=4)
table.cell(1, 3).value = '合并2個單元格'
# 法一不適合批量添加
for i in range(2,10):
 table.merge_cells(start_row=i, start_column=3, end_row=i, end_column=4)

效果如下:

補充:python操作excel --openpyxl里的關于merge的一些bug

開始新的工作不久,工作內容依然是數據相關

新工作數據輸出模式是用excel,大概是每天導出新數據并用excel體現,同時要保留之前的數據。

我來之前,同時寫好了許多sql,然后就從Navicat里面復制粘貼到excel中。

我目前在做關于這個的自動化腳本,使用的庫是openpyxl,下面說說關于這個的幾個小bug。

1- 在 2.5.x版本中,當你合并單元格的時候

使用的是merge_cells(),然后,當你合并多個單元格的時候,之前合并的單元格的邊框會消失。這個問題我再官網找到解決方案,稍有復雜,但是只要你更新到2.6.x版本,這個問題自動解決。

2- 2.6x版本中,使用unmerge_cell() 解開合并單元格后,除了左上角可以寫入,其他被解開的單元格無法寫入,會提示說 ‘read_only'這類的。

例如:你的 ("A1:D4") 是合并的,當你使用 work_sheet.unmerge_cell("A1:D4")后,會解開合并,

然后你卻只能給A1賦值,不能給A2,A3,A4,B1....賦值,提示如下

=== > - Openpyxl ['MergedCell' object attribute 'hyperlink' is read-only]

我嘗試改用delete直接刪除,然而這種方法只能刪除內容,格式還是被鎖定的。

找了很久沒有結局方法,只好慢慢看源碼。

大概是說,接觸合并后,代碼默認其他單元格應該是空值且不能被賦新值,也許是因為覺得解開只有要再合并??(不明白設疑初衷)

處理方法如下,大概思想是格式化該單元格的屬性,即取消的read_only屬性。

大概在源碼的中workshet.py文件的大約620做添加如下代碼:(# autho...開始,大家自己對照源碼添加吧~~~)

........................ 
 if cr.coord not in self.merged_cells:
  raise ValueError("Cell range {0} is not merged".format(cr.coord))
 
 self.merged_cells.remove(cr) 
 # Deletes the MergedCellRange.
 # del self._merged_cell_range[cr.bounds]
 # autho : watson
 # aim : deal with the bug about umerger
 # describe : Add the following five lines of code to format the attribute.
 min_col, min_row, max_col, max_row = cr.bounds
 for row in range(min_row, max_row + 1):
  for col in range(min_col, max_col + 1):
  if col == min_col and row == min_row:
   continue
  del self._cells[(row, col)]
 
 def append(self, iterable):
 """Appends a group of values at the bottom of the current sheet.
........................ 

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。

您可能感興趣的文章:
  • 解決使用openpyxl時遇到的坑
  • python openpyxl 帶格式復制表格的實現
  • python openpyxl篩選某些列的操作
  • python中openpyxl和xlsxwriter對Excel的操作方法
  • 詳解Python openpyxl庫的基本應用
  • python openpyxl模塊的使用詳解
  • Python openpyxl 無法保存文件的解決方案

標簽:浙江 西寧 懷化 梅州 文山 昆明 石家莊 錫林郭勒盟

巨人網絡通訊聲明:本文標題《淺談openpyxl庫,遇到批量合并單元格的問題》,本文關鍵詞  淺談,openpyxl,庫,遇到,批量,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《淺談openpyxl庫,遇到批量合并單元格的問題》相關的同類信息!
  • 本頁收集關于淺談openpyxl庫,遇到批量合并單元格的問題的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 甘孜| 巴林左旗| 潼南县| 喀喇沁旗| 静乐县| 嘉鱼县| 平和县| 罗源县| 女性| 清远市| 克什克腾旗| 富锦市| 白玉县| 阿巴嘎旗| 清涧县| 明光市| 灵台县| 常熟市| 洞口县| 尼勒克县| 五河县| 错那县| 临漳县| 淅川县| 来安县| 睢宁县| 临猗县| 崇州市| 乐安县| 长汀县| 嘉义县| 靖江市| 湟中县| 新宁县| 调兵山市| 自治县| 宁晋县| 淮北市| 阿拉尔市| 保靖县| 宁国市|