Python读写Excel文件

python如何读写excel文件

python读写excel的方式有很多,不同的模块在读写的方法上稍有区别:

用xlrd和xlwt进行excel读写;

用openpyxl进行excel读写;

用pandas进行excel读写;、

Python使用openpyxl读写excel文件


这是一个第三方库,可以处理xlsx格式的Excel文件。pip install openpyxl安装。如果使用Aanconda,应该自带了。

假设操作的表如下:放在D盘的test.xlsx文件

姓名性别
张三
李四

读取Excel文件
需要导入相关函数。

#coding=gbk

from openpyxl import load_workbook


wb = load_workbook('D:/test.xlsx')

获取工作表--Sheet
# 获得所有sheet的名称
print(wb.get_sheet_names())
# 根据sheet名字获得sheet
a_sheet = wb.get_sheet_by_name('Sheet1')
# 获得sheet名
print(a_sheet.title)
# 获得当前正在显示的sheet, 也可以用wb.get_active_sheet()
sheet = wb.active
获取单元格
# 获取某个单元格的值,观察excel发现也是先字母再数字的顺序,即先列再行

b3 = worksheet['B3']
print('B3是----',b3) # 返回的数字就是int型
print(f'({b3.column}, {b3.row}) is {b3.value}') # 返回的数字就是int型

结果为:

B3是---- <Cell 'Sheet1'.B3>
(2, 3) is 女

cell_2_2=worksheet.cell(row=2,column=2)
cell_2_2_value=worksheet.cell(row=2,column=2).value
print('第2行第2列',cell_2_2)
print('第2行第2列值',cell_2_2_value)

返回结果:

第2行第2列 <Cell 'Sheet1'.B2>
第2行第2列值 男

获得最大行和最大列
# 获得最大列和最大行

print('最大行数---', worksheet.max_row)
print('最大列数---', worksheet.max_column)

返回结果:

最大行数--- 3
最大列数--- 2


获取行和列

row3=[item.value for item in list(worksheet.rows)[2]]
print('第3行值',row3)
col2=[item.value for item in list(worksheet.columns)[1]]
print('第2列值',col2)

结果是:

第3行值 ['李四', '女']
第2列值 ['性别', '男', '女']

获取列表说有数据:

# print('通过worksheet.cell获取所有数据方法一:')
# for i in range(1, 4):
#     for j in range(1, 3):
#         print(worksheet.cell(row=i, column=j))

print('通过worksheet.cell获取所有数据方法二:')
for row_cell in worksheet['A1':'B3']:
    for cell in row_cell:
        print(cell)

通过worksheet.cell获取所有数据方法二:
<Cell 'Sheet1'.A1>
<Cell 'Sheet1'.B1>
<Cell 'Sheet1'.A2>
<Cell 'Sheet1'.B2>
<Cell 'Sheet1'.A3>
<Cell 'Sheet1'.B3>


将数据写入Excel

需要导入WorkBook

from openpyxl import Workbook
wb = Workbook()
这样就新建了一个新的工作表(只是还没被保存)。

若要指定只写模式,可以指定参数write_only=True。一般默认的可写可读模式就可以了。

print(wb.get_sheet_names()) # 提供一个默认名叫Sheet的表,office2016下新建提供默认Sheet1
# 直接赋值就可以改工作表的名称
sheet.title = 'Sheet1'
# 新建一个工作表,可以指定索引,适当安排其在工作簿中的位置
wb.create_sheet('Data', index=1) # 被安排到第二个工作表,index=0就是第一个位置
# 删除某个工作表
wb.remove(sheet)
del wb[sheet]
写入单元格
还可以使用公式哦

# 直接给单元格赋值就行
sheet['A1'] = 'good'
# B9处写入平均值
sheet['B9'] = '=AVERAGE(B2:B8)'

wb.save(r'D:\example.xlsx')

wb.save(r'D:\example.xlsx')
 

  • 12
    点赞
  • 104
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
### 回答1: 可以使用 pandas 库中的 read_excel() 函数来读取 Excel 文件,示例代码如下: ```python import pandas as pd # 读取 Excel 文件 df = pd.read_excel('example.xlsx', sheet_name='Sheet1') # 打印读取的数据 print(df) ``` 其中,'example.xlsx' 是 Excel 文件的路径,'Sheet1' 是要读取的工作表名称。read_excel() 函数还有很多参数可以设置,具体可以参考 pandas 文档。 ### 回答2: Python读取Excel文件可以使用第三方库如`pandas`和`openpyxl`。下面以`pandas`为例介绍如何读取Excel文件。 1. 安装pandas库:在命令行中运行`pip install pandas`命令,安装最新版本的pandas库。 2. 导入pandas库:在Python代码中导入pandas库,`import pandas as pd`。 3. 使用pandas读取Excel文件:使用`pd.read_excel()`函数来读取Excel文件。例如,如果要读取名为`data.xlsx`的Excel文件,可以使用以下代码: ```python data = pd.read_excel('data.xlsx') ``` 这将把Excel文件中的数据读取到一个名为`data`的DataFrame对象中。 4. 处理Excel数据:读取Excel文件后,可以对数据进行各种操作,如筛选、排序、计算等。例如,可以使用`head()`函数查看前几行数据: ```python print(data.head()) ``` 5. 保存结果:如果需要将处理后的数据保存为Excel文件,可以使用`to_excel()`函数。例如,将处理后的数据保存为名为`result.xlsx`的文件: ```python data.to_excel('result.xlsx', index=False) ``` 这将生成一个不包含索引的Excel文件。 总结:使用`pandas`库的`read_excel()`函数可以方便地读取Excel文件,然后可以对数据进行各种处理和保存。通过这些简单的步骤,我们可以轻松地在Python读取和处理Excel文件。 ### 回答3: Python读取Excel文件的主要方式是使用第三方库:openpyxl和pandas。 使用openpyxl库可以实现对Excel文件读取和写入操作。首先,我们需要安装openpyxl库。然后,导入openpyxl模块,使用`load_workbook`函数加载Excel文件,再选择指定的工作表。接着,我们可以通过读取单元格的值、行或列的数据等方式来获取Excel文件中的数据。 另一个常用的库是pandas,它提供了更高级的Excel文件读取和处理功能。首先,我们需要安装pandas库。然后,导入pandas模块,使用`read_excel`函数来读取Excel文件。这个函数可以直接读取整个Excel文件或选择指定的工作表。我们可以通过DataFrame数据结构或`values`属性来获取Excel文件中的数据。 无论使用openpyxl还是pandas,读取Excel文件的过程中,我们需要注意文件路径的正确设置,并确保Excel文件格式正确。 总的来说,Python读取Excel文件的过程需要依托openpyxl或pandas等库来实现。通过这些库,我们可以方便地读取Excel文件中的数据,并进行后续的处理和分析。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值