xlwings删除数据_xlwings最全操作;10秒搞定Xlwings全套操作
import xlwings as xw
app = xw.App(visible=True, add_book=False)
app.display_alerts = False # 關閉一些提示信息,可以加快運行速度。 默認為 True。
app.screen_updating = True # 更新顯示工作表的內容。默認為 True。關閉它也可以提升運行速度。
wb = app.books.add()
sht = wb.sheets.active
'''工作簿'''
# wb = app.books.add() # 新建工作簿。
# wb = app.books.open(r'file_path') # 打開現有的工作簿
# wb = app.books.active # 獲取當前活動的工作簿
"""工作表"""
# sht = wb.sheets.active # 獲取當前活動的工作表
# sht = wb.sheets[0] # 按索引獲取工作表
# sht = wb.sheets['Sheet1'] # 按表名獲取工作表
# sht1 = wb.sheets.add() # 新建工作表,默認新建的放在最前面。
# sht1 = wb.sheets.add('新建工作表', after=sht) # 新建工作表,放在sht工作表后面。
""" 讀取單元格 """
b3 = sht.range('b3')
# 獲取 b3 中的值
v = b3.value
# 也可以根據行列號讀取
b3_value = sht.range(3,2).value
# 讀取一段區間內的值
a1_c4_value = sht.range('a1:c4').options(ndim=2).value # 加上 option 讀取二維的數據
a1_c4_value = sht.range((1,1),(4,3)).options(ndim=2).value # 和上面讀取的內容一樣。
""" 寫入 就是把值賦值給讀取的單元格就可以了"""
sht.range(3,2).value = 'b3'
"""設置單元格大小"""
sht.autofit() # 自動調整單元格大小。注:此方法是在單元格寫入內容后,再使用,才有效。
sht.range(1,4).column_width = 5 # 設置第4列 列寬。(1,4)為第1行第4列的單元格
sht.range(1,4).row_height = 20 # 設置第1行 行高
"""設置單元格 字體格式"""
b3.color = 255,200,255 # 設置單元格的填充顏色
b3.api.Font.ColorIndex = 3 # 設置字體的顏色,具體顏色索引見下方。
b3.api.Font.Size = 24 # 設置字體的大小。
b3.api.Font.Bold = True # 設置為粗體。
b3.api.HorizontalAlignment = -4108 # -4108 水平居中。 -4131 靠左,-4152 靠右。
b3.api.VerticalAlignment = -4130 # -4108 垂直居中(默認)。 -4160 靠上,-4107 靠下, -4130 自動換行對齊。
b3.api.NumberFormat = "0.00" # 設置單元格的數字格式。
"""設置邊框"""
# Borders(9) 底部邊框,LineStyle = 1 直線。
b3.api.Borders(9).LineStyle = 1
b3.api.Borders(9).Weight = 3 # 設置邊框粗細。
# Borders(7) 左邊框,LineStyle = 2 虛線。
b3.api.Borders(7).LineStyle = 2
b3.api.Borders(7).Weight = 3
# Borders(8) 頂部框,LineStyle = 5 雙點劃線。
b3.api.Borders(8).LineStyle = 5
b3.api.Borders(8).Weight = 3
# Borders(10) 右邊框,LineStyle = 4 點劃線。
b3.api.Borders(10).LineStyle = 4
b3.api.Borders(10).Weight = 3
# Borders(5) 單元格內從左上角 到 右下角。
b3.api.Borders(5).LineStyle = 1
b3.api.Borders(5).Weight = 3
# Borders(6) 單元格內從左下角 到 右上角。
b3.api.Borders(6).LineStyle = 1
b3.api.Borders(6).Weight = 3
"""如果是一個區域的單元格,內部邊框設置如下"""
# # Borders(11) 內部垂直邊線。
# b3.api.Borders(11).LineStyle = 1
# b3.api.Borders(11).Weight = 3
#
# # Borders(12) 內部水平邊線。
# b3.api.Borders(12).LineStyle = 1
# b3.api.Borders(12).Weight = 3
"""合并拆分單元格"""
sht.range('C8:D8').api.merge() # 合并單元格 C8 到 D8
sht.range('C8:D8').api.unmerge() # 拆分單元格。
'''插入 、刪除 一行'''
sht1.range('a3').api.EntireRow.Delete() # 會刪除 ’a3‘ 單元格所在的行。
sht1.api.Rows(3).Insert() # 會在第3行插入一行,原來的第3行下移。
'''插入 、刪除 一列'''
sht1.range('c2').api.EntireColumn.Delete() # 會刪除 ’c2‘ 單元格所在的列。
sht1.api.Columns(3).Insert() # 會在第3列插入一列,原來的第3列右移。(也可以用列的字母表示)
'''選擇sheet頁面最右下角的單元格,獲取最大行數,和列數'''
# 區別 expand(), expand()只選中與之連續的單元格。
cell = sht1.used_range.last_cell
rows = cell.row
columns = cell.column
# cell = sht1.range("a1").expand("down")
# max_rows = cell.rows.count # 獲取最大行數
'''排序,刪除重復值'''
# 排序使用方法:
# 1、選擇需要排序的區域。這里用 'a2' 是因為排序的數據送從第二行開始的,第一行是標題,不應該參與排序。
# 2、選擇按那一列進行排序 Key1=sht.range('c2').api, 這里選擇的是按 第 C 列排序,所以這里選擇 c1 和 c2 都可以。
# 3、Order1=1 為升序,2為降序。
sht1.range('a2',(rows,columns)).api.Sort(Key1=sht.range('c2').api, Order1=1)
# 刪除重復值使用方法:
# RemoveDuplicates(3) 為按第3列內容進行刪除重復項。
sht1.range('a2',(rows,columns)).api.RemoveDuplicates(3)
"""插入、讀取公式"""
sht1.range('d1').formula = '=sum(e1+f1)' # 插入公式
print(sht1.range('d1').formula)
'''同個表格復制、粘貼'''
# 復制 a2 到 a6 之間單元格的值,粘貼到'a15'中
sht.range('a2','a6').api.Copy(sht.range('a15').api)
'''跨表格復制、粘貼'''
my_values = sht_1.range('a2:d4').options(ndim=2).value # 讀取二維的數據
sht_2.range('a1').value = my_values
wb.save()
#wb.close()
#app.quit()
總結
以上是生活随笔為你收集整理的xlwings删除数据_xlwings最全操作;10秒搞定Xlwings全套操作的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: java.lang.OutOfMemor
- 下一篇: 油猴脚本hook cookie 生成