使用py对Excel表格进行基本读写操作

使用py对Excel表格进行基本读写操作

在处理Richard给的Task时觉得使用python直接对Excel表格进行读写操作会比较方便,所以学了如何用py对Excel表格进行基本的读写操作。虽然简单但是也需要学习成本,所以写下来以供以后查阅。

所需库

​ 虽然pandas的dataframe也能和Excel进行交互,但是操纵起来没有那么的灵活。Python中有两个包,专门用来对Excel表格进行细致的操作:

  • 负责读:xlrd [https://xlrd.readthedocs.io/en/latest/api.html]
  • 负责写:xlwt [https://xlwt.readthedocs.io/en/latest/api.html]

​ spyder中好像太有这两个包的提示信息(按Tab键啥也没有),很多CSDN笔记也记录的粗略,还是官网给出的比较详细

数据结构

​ xlrd和xlwt中,把每个Excel文件都看作是一个WorkBook,而WorkBook中包含若干sheet,这些sheet对应于Excel中的sheet。而每个sheet又是由cell组成的,cell就是Excel表格中的一个单元格,它是xlrd中的数据结构,它包含若干property,包括值等。

xlrd库基本操作

以下栗子均来源于D:\CodeLab\PythonProject\AI\PythonDict\abstract_questions.py

读取一个Excel文件
rbook = xlrd.open_workbook("questions_classification.xlsx")
读取一个WorkBook中的一个sheet

读取sheet可以按下标读(从0开始)也可以按名字读

classification = rbook.sheet_by_name("questions classification")
classification = rbook.sheet_by_index(0)
读取某sheet中的cell

cell是xlrd中的数据结构,要分清楚是读值还是读cell对象

读取cell的方式有很多,可以多行,多列,也可以单个单元格,由不同函数实现特定功能

  • classification.col_values(n) 所要读取的列序号
# 直接读数值是float类型,读出的值会被存放在list之中,使用map函数对list中每个元素进行转int操作
# 读数值
questionId = list(map(int, classification.col_values(0)[1 : ]))	
# 读cell对象
classification.col(0, start_rowx=0, end_rowx=None) 

xlwt库基本操作

打开一个Excel文件

打开一个Excel文件分为打开一个新的文件和打开一个已经存在的文件。打开一个已经存在的文件没有直接的实现函数,而是借由xlutils包下的copy函数实现

  • xlrd.open_workbook(fileName) 打开fileName的文件
  • wbook.copy(rbook) 把rbook内容复制到wbook
# 打开一个新的Workbook(其实就是创建新对象)
wbook = xlwt.Workbook(encoding='ascii')

# 打开一个新的Workbook并把已存在文件的内容读入新的Workbook中
from xlutils import copy
rbook = xlrd.open_workbook("questions_classification.xlsx")
wbook = xlwt.Workbook(encoding='ascii')
wbook.copy(rbook)
向打开的文件写入数据

在写入数据之前要创新的sheet,之后就可以向sheet中写入数据了

  • wbook.add_sheet(sheetName) 追加新sheet,参数可以是sheet的名字
  • wbook.write(x, y, label = content) 向sheet中的(x, y)处写入content
# 创建新的sheet
wsheet = wbook.add_sheet("questions")

# 向指定位置写入数据
wsheet.write(0, 0, label="Question ID")
保存文件

我在保存为.xlsx文件时发生了错误,并不明白为啥,就存成了.xls文件。但是这对数据处理所需的Excel表格就够了

# 保存为questions_classification_v3.xls
wbook.save("questions_classification_v3.xls")
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 好的,这是一段使用 Python 操作 Excel 表格的代码示例: 首先,你需要安装 openpyxl 库,这是一个用于读写 Excel 2010 xlsx/xlsm/xltx/xltm 文件的 Python 库。你可以使用 pip 安装它: ``` pip install openpyxl ``` 然后,你可以使用以下代码来读取 Excel 表格: ```python import openpyxl # 打开一个工作簿 wb = openpyxl.load_workbook('example.xlsx') # 获取所有的工作表名称 sheets = wb.sheetnames # 获取某个工作表 ws = wb[sheets[0]] # 遍历工作表的每一行 for row in ws.rows: # 遍历每一列 for cell in row: # 输出单元格的值 print(cell.value) ``` 要写入 Excel 表格,你可以使用以下代码: ```python import openpyxl # 创建一个工作簿 wb = openpyxl.Workbook() # 获取当前活动的工作表 ws = wb.active # 写入数据 ws['A1'] = 'hello' ws['B1'] = 'world' # 保存工作簿 wb.save('example.xlsx') ``` 希望这能帮到你! ### 回答2: 使用Python操作Excel表格的最常用方法是使用第三方库openpyxl。以下是一个简单的示例代码,展示了如何使用openpyxl打开一个Excel文件、读取数据、修改数据,并保存修改后的文件。 ```python import openpyxl # 打开Excel文件 wb = openpyxl.load_workbook('example.xlsx') # 选择要操作的工作表 sheet = wb.active # 读取数据 cell_value = sheet.cell(row=1, column=1).value print(cell_value) # 修改数据 sheet.cell(row=1, column=1).value = 'New Value' # 保存修改后的文件 wb.save('example_modified.xlsx') ``` 在上面的示例中,我们使用`openpyxl.load_workbook`函数打开了一个名为`example.xlsx`的Excel文件,并使用`wb.active`选择了默认的工作表。然后,我们使用`sheet.cell`方法读取了第1行第1列单元格的值,并将其打印出来。接下来,我们使用`sheet.cell`方法将第1行第1列单元格的值修改为'New Value'。最后,我们使用`wb.save`方法保存修改后的Excel文件,将其保存为`example_modified.xlsx`。 当然,openpyxl还提供了其他强大的功能,如创建新的工作表、添加数据、删除数据等。你可以查阅openpyxl的官方文档来了解更多关于使用openpyxl操作Excel表格的方法和功能。 ### 回答3: 以下是一段用Python操作Excel表格的代码: ```python import openpyxl # 打开Excel文件 workbook = openpyxl.load_workbook('sample.xlsx') # 选择某个工作表 sheet = workbook['Sheet1'] # 读取单元格的数据 cell_value = sheet['A1'].value print(cell_value) # 修改某个单元格的数据 sheet['B2'] = 'Hello World' # 保存修改后的Excel文件 workbook.save('sample_modified.xlsx') # 关闭Excel文件 workbook.close() ``` 这段代码使用了`openpyxl`库来处理Excel文件。首先通过`load_workbook()`函数打开Excel文件,然后选取了其中的一个工作表。接着通过`sheet['A1'].value`来读取A1单元格的值,并将其打印出来。然后,将'B2'单元格的值修改为'Hello World'。最后,通过`save()`函数将修改后的Excel文件保存为新文件,并使用`close()`函数关闭Excel文件。 上述代码只是一个简单的示例,你可以根据自己的需求进一步扩展和修改。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值