excel相關

来源:https://www.cnblogs.com/JcrLive/archive/2020/03/22/12548679.html
-Advertisement-
Play Games

xlrd openpyxl 庫 應該是自帶了,反正我是沒安裝,csv也可製作表格,關於csv以後介紹 基本操作 import xlrd book = xlrd.open_workbook('filename') book.nsheets # 表單數量 book.sheet_names() # 表單名 ...


xlrd   openpyxl  庫

應該是自帶了,反正我是沒安裝,csv也可製作表格,關於csv以後介紹

基本操作

 

import xlrd
book = xlrd.open_workbook('filename')
book.nsheets   # 表單數量
book.sheet_names()  # 表單名



要讀取某個表單里單元格中的數據,必須要先獲取 表單(sheet)對象 。
# 表單索引從0開始,獲取第一個表單對象
book.sheet_by_index(0)

# 獲取名為2018的表單對象
book.sheet_by_name('2018')

# 獲取所有的表單對象,放入一個列表返回
book.sheets()
官方文檔:https://xlrd.readthedocs.io/en/latest/api.html#xlrd-sheet


表單行數(nrows)
列數(ncols)
表單名(name)
表單索引(number)




'''
book = xlrd.open_workbook("income.xlsx")

sheet = book.sheet_by_index(0)
sheet.name
sheet.number
sheet.nrows
sheet.ncols
'''

cell_value 方法,參數為行號和列號,讀取指定單元格中的文本內容。

sheet.cell_value(rowx=0, colx=0)

row_values 方法,參數為行號,讀取指定行所有單元格的內容,存放在一個列表中返回。

sheet.row_values(rowx=0)

col_values 方法,參數為列號,讀取指定列所有單元格的內容,存放在一個列表中返回。

sheet.col_values(colx=0)
其他參數可自己看源碼 =_=

 

 

import openpyxl

# 創建一個Excel workbook 對象
book = openpyxl.Workbook()

# 創建時,會自動產生一個sheet,通過active獲取
sh = book.active

# 修改當前 sheet 標題為 工資表
sh.title = '工資表'

# 保存文件
book.save('信息.xlsx')





# 增加一個名為 '年齡表' 的sheet,放在最後
sh1 = book.create_sheet('年齡表-最後')

# 增加一個 sheet,放在最前
sh2 = book.create_sheet('年齡表-最前',0)

# 增加一個 sheet,指定為第2個表單
sh3 = book.create_sheet('年齡表2',1)

# 根據名稱獲取某個sheet對象
sh = book['工資表']





# 給第一個單元格寫入內容
sh['A1'] = '你好'

# 獲取某個單元格內容
print(sh['A1'].value)

# 根據行號列號, 給第一個單元格寫入內容,
# 註意和 xlrd 不同,是從 1 開始
sh.cell(2,2).value = 'zzz'

# 根據行號列號, 獲取某個單元格內容
print(sh.cell(1, 1).value)

book.save('信息.xlsx')




name2Age = {
    '張飛' :  38,
    '趙雲' :  27,
    '許褚' :  36,
    '典韋' :  38,
    '關羽' :  39,
    '黃忠' :  49,
    '徐晃' :  43,
    '馬超' :  23,
}

# 創建一個Excel workbook 對象
book = openpyxl.Workbook()

# 創建時,會自動產生一個sheet,通過active獲取
sh = book.active

sh.title = '年齡表'

# 寫標題欄
sh['A1'] =  '姓名'
sh['B1'] =  '年齡'

# 寫入內容
row = 2

for name,age in name2Age.items():
    sh.cell(row, 1).value = name
    sh.cell(row, 2).value = age
    row += 1

# 保存文件
book.save('信息.xlsx')

 

 

import openpyxl

# 載入 excel 文件
wb = openpyxl.load_workbook('income.xlsx')

# 得到sheet對象
sheet = wb['2017']

sheet['A1'] = '修改一下'

## 指定不同的文件名,可以另存為別的文件
wb.save('income-1.xlsx')



insert_rows 和 insert_cols 方法,分別用來插入 行 和 列

wb = openpyxl.load_workbook('income.xlsx')
sheet = wb['2018']

# 在第2行的位置插入1行
sheet.insert_rows(2)

# 在第3行的位置插入3行
sheet.insert_rows(3,3)

# 在第2列的位置插入1列
sheet.insert_cols(2)

# 在第2列的位置插入3列
sheet.insert_cols(2,3)






delete_rows 和 delete_cols 方法,分別用來插入 行 和 列

wb = openpyxl.load_workbook('income.xlsx')
sheet = wb['2018']

# 在第2行的位置刪除1行
sheet.delete_rows(2)

# 在第3行的位置刪除3行
sheet.delete_rows(3,3)

# 在第2列的位置刪除1列
sheet.delete_cols(2)

# 在第3列的位置刪除3列
sheet.delete_cols(3,3)

 

 

文字     顏色、字體、大小、下劃線 等

import openpyxl
# 導入Font對象 和 colors 顏色常量
from openpyxl.styles import Font,colors

wb = openpyxl.load_workbook('income.xlsx')
sheet = wb['2018']

# 指定單元格字體顏色,
sheet['A1'].font = Font(color=colors.RED, #使用預置的顏色常量
                        size=15,    # 設定文字大小
                        bold=True,  # 設定為粗體
                        italic=True # 設定為斜體
                        )

# 也可以使用RGB數字表示的顏色
sheet['B1'].font = Font(color="981818")

# 指定整行 字體風格, 這裡指定的是第3行
font = Font(color="981818")
for y in range(1, 100): # 第 1 到 100 列
    sheet.cell(row=3, column=y).font = font

# 指定整列 字體風格, 這裡指定的是第2列
font = Font(bold=True)
for x in range(1, 100): # 第 1 到 100 行
    sheet.cell(row=x, column=2).font = font

wb.save('income-1.xlsx')


背景色

import openpyxl
# 導入Font對象 和 colors 顏色常量
from openpyxl.styles import PatternFill

wb = openpyxl.load_workbook('income.xlsx')
sheet = wb['2018']

# 指定 某個單元格背景色
sheet['A1'].fill = PatternFill("solid", "E39191")

# 指定 整行 背景色, 這裡指定的是第2行
fill = PatternFill("solid", "E39191")
for y in range(1, 100): # 第 1 到 100 列
    sheet.cell(row=2, column=y).fill = fill

wb.save('income-1.xlsx')


插入圖片


import openpyxl
from openpyxl.drawing.image import Image

wb = openpyxl.load_workbook('income.xlsx')
sheet = wb['2018']

# 在第1行,第4列 的位置插入圖片
sheet.add_image(Image('1.png'), 'D1')

## 指定不同的文件名,可以另存為別的文件
wb.save('income-1.xlsx')
其他

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 現在springboot的火熱程度已經超過了spring了,因為springboot簡單快速方便,springboot的初衷就是為了簡化spring的配置,是的開發中集成新功能時更快,簡化或者減少相關的配置。springboot的基礎是“約定大於配置”。整合了所有的框架,可以把springboot當 ...
  • ...
  • [TOC] 環境 idea 2019.1 Meavn 3.6.0 SpringBoot 2.2.5 jdk 1.8 構建eureka server 新建工程 啟動類添加註解 @EnableEurekaServer 其他配置 構建eureka client 新建工程 pom文件添加依賴,解決啟動失敗 ...
  • 距離Java 8發佈已經過去了7、8年的時間,Java 14也剛剛發佈。Java 8中關於函數式編程和新增的Stream流API至今飽受“爭議”。 如果你不曾使用Stream流,那麼當你見到Stream操作時一定對它發出過鄙夷的聲音,併在心裡說出“這都寫的什麼玩意兒”。 如果你熱衷於使用Stream ...
  • 恢復內容開始 1.背景:現在很多app或者網站都想要接入微信登錄,可以使用戶不需要註冊就能快速使用APP或網站。 2.微信登錄需要一些前置操作 2.1 搜索:微信開放平臺 鏈接:https://open.weixin.qq.com/ 2.2 註冊成功,獲取到開發所需要的appID和appsecret ...
  • elastic4s是elasticsearch一個第三方開發的scala語言終端工具庫(Elastic4s is a concise, idiomatic, reactive, type safe Scala client for Elasticsearch.)。scala用戶可以用elastic4 ...
  • 1. 不可變的PyIntObject "Python源碼剖析 對象初探" 我們對 PyIntObject 已經有了初步的瞭解。 Python 中的對象可以分為固定長度和可變長度兩種類型。除此之外,也可以按照可變和不可變進行劃分。 PyIntObject 則屬於長度固定且不可變的對象。相比其他的對象而 ...
  • 【qdox】Java 代碼解析利器 QDox 前言 最近在寫 maven 插件,涉及到了 java 代碼解析這塊內容。需要解析 java 源碼,然後對於類中的不同部分進行處理。發現手寫還是很難的,找了一圈發現了兩個不錯的工具可以使用,一個是 "javaparser" ,另一個是 "qdox" 。個人 ...
一周排行
    -Advertisement-
    Play Games
  • .Net8.0 Blazor Hybird 桌面端 (WPF/Winform) 實測可以完整運行在 win7sp1/win10/win11. 如果用其他工具打包,還可以運行在mac/linux下, 傳送門BlazorHybrid 發佈為無依賴包方式 安裝 WebView2Runtime 1.57 M ...
  • 目錄前言PostgreSql安裝測試額外Nuget安裝Person.cs模擬運行Navicate連postgresql解決方案Garnet為什麼要選擇Garnet而不是RedisRedis不再開源Windows版的Redis是由微軟維護的Windows Redis版本老舊,後續可能不再更新Garne ...
  • C#TMS系統代碼-聯表報表學習 領導被裁了之後很快就有人上任了,幾乎是無縫銜接,很難讓我不想到這早就決定好了。我的職責沒有任何變化。感受下來這個系統封裝程度很高,我只要會調用方法就行。這個系統交付之後不會有太多問題,更多應該是做小需求,有大的開發任務應該也是第二期的事,嗯?怎麼感覺我變成運維了?而 ...
  • 我在隨筆《EAV模型(實體-屬性-值)的設計和低代碼的處理方案(1)》中介紹了一些基本的EAV模型設計知識和基於Winform場景下低代碼(或者說無代碼)的一些實現思路,在本篇隨筆中,我們來分析一下這種針對通用業務,且只需定義就能構建業務模塊存儲和界面的解決方案,其中的數據查詢處理的操作。 ...
  • 對某個遠程伺服器啟用和設置NTP服務(Windows系統) 打開註冊表 HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\W32Time\TimeProviders\NtpServer 將 Enabled 的值設置為 1,這將啟用NTP伺服器功 ...
  • title: Django信號與擴展:深入理解與實踐 date: 2024/5/15 22:40:52 updated: 2024/5/15 22:40:52 categories: 後端開發 tags: Django 信號 松耦合 觀察者 擴展 安全 性能 第一部分:Django信號基礎 Djan ...
  • 使用xadmin2遇到的問題&解決 環境配置: 使用的模塊版本: 關聯的包 Django 3.2.15 mysqlclient 2.2.4 xadmin 2.0.1 django-crispy-forms >= 1.6.0 django-import-export >= 0.5.1 django-r ...
  • 今天我打算整點兒不一樣的內容,通過之前學習的TransformerMap和LazyMap鏈,想搞點不一樣的,所以我關註了另外一條鏈DefaultedMap鏈,主要調用鏈為: 調用鏈詳細描述: ObjectInputStream.readObject() DefaultedMap.readObject ...
  • 後端應用級開發者該如何擁抱 AI GC?就是在這樣的一個大的浪潮下,我們的傳統的應用級開發者。我們該如何選擇職業或者是如何去快速轉型,跟上這樣的一個行業的一個浪潮? 0 AI金字塔模型 越往上它的整個難度就是職業機會也好,或者說是整個的這個運作也好,它的難度會越大,然後越往下機會就會越多,所以這是一 ...
  • @Autowired是Spring框架提供的註解,@Resource是Java EE 5規範提供的註解。 @Autowired預設按照類型自動裝配,而@Resource預設按照名稱自動裝配。 @Autowired支持@Qualifier註解來指定裝配哪一個具有相同類型的bean,而@Resourc... ...