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
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...