当前位置:   article > 正文

python对excel大量数据进行处理

python对excel大量数据进行处理

大家好,小编来为大家解答以下问题,一个有趣的事情,一个有趣的事情,今天让我们一起来看看吧!


当Excel中有大量需要进行处理的数据时,使用Python不失为一种便捷易学的方法。接下来,本文将详细介绍多种Python方法来处理Excel数据 Python中的所有运算符号

Excel处理经常用于数据可视化,那么如何利用提取到的Excel数据绘图呢?

本文搭配Python绘图 \ 数据可视化一起使用效果更佳。

电子表格格式

我们在日常工作中常常见到各种后缀的电子表格,例如最常见的xlsx以及较为常见的csv、xls等格式的表格。同样是电子表格,它们之间有什么区别吗?

xls为Excel早期表格格式。

xls格式是Excel2003版本及其以前版本所生成的文件格式。 其最大的特点就是:仅有65536行、256列。因此规模过大的数据不可以使用xls格式读写。

xlsx为Excel2007及其之后的表格格式,也是现在Excel表格的主流格式。

与xls相比,它可以存储1048576行、16384列数据,存储相同数据,xlsx格式要比xls格式文件要小得很多。

CSV为逗号分隔值文件。

CSV逗号分隔值文件格式,其以纯文本形式存储表格数据(数字和文本),可以用Excel软件打开。

xlrd 模块既可读取 xls 文件也可读取 xlsx 文件;xlwt只可写 xlsx 文件;openpyxl 可以读写 xlsx 文件;pandas 可以同时读写 xls、xlsx 文件。

经评论区提醒发现,xlrd 2.0.0 及更高版本只能读取 .xls 文件,建议使用其他库读取 .xlsx文件 或 安装 xlrd 早期版本。

1.使用 xlrd 来处理;

xlrd命令

  1. import xlrd
  2. book = xlrd.open_workbook('excelFile.xlsx') # 获取工作簿对象
  3. names = book.sheet_names() # 获取所有工作表名称结果为列表
  4. mySheets = book.sheets() # 获取工作表list。
  5. sheet = mySheets[0] # 通过索引顺序获取。
  6. sheet = book.sheet_by_index(0) # 通过索引顺序获取。
  7. sheet = book.sheet_by_name(u'Sheet1') # 通过名称获取 u表示后面字符串以 Unicode 格式 进行编码,一般用在中文字符串前面,以防乱码
  8. # 获取行数和列数
  9. nrows = sheet.nrows
  10. ncols = sheet.ncols
  11. # 获取一行和一列
  12. row = sheet.row_values(i) # i是行数,从0开始计数,返回list对象。
  13. col = sheet.col_values(i) # i是列数,从0开始计数,返回list对象。
  14. # 读取单元格数据
  15. cell = sheet.cell_value(i, j) # 直接获取单元格数据,i是行数,j是列数,行数和列数都是从0开始计数。
  16. cell = sheet.cell(i,j).value

示例1:Python读取Excel文件特定数据

  1. import xlrd
  2. data = xlrd.open_workbook('excelFile.xlsx') # 打开xlsx文件
  3. table = data.sheets()[0] # 打开第一张表
  4. nrows = table.nrows # 获取表的行数
  5. # 循环逐行输出
  6. for i in range(nrows):
  7. if i == 0: # 跳过第一行
  8. continue
  9. print(table.row_values(i)[:5]) # 取前五列数据

示例2:Python读取Excel文件所有数据

  1. import xlrd
  2. workbook = xlrd.open_workbook('excelFile.xlsx') # 打开一个xlsx文件
  3. worksheets = workbook.sheet_names() # 抓取所有sheet页的名称
  4. print('worksheets is %s' %worksheets)
  5. worksheet1 = workbook.sheet_by_name(u'Sheet1') # 如果存在sheet1文件则定位到sheet1
  6. """
  7. #遍历所有sheet对象
  8. for worksheet_name in worksheets:
  9. worksheet = workbook.sheet_by_name(worksheet_name)
  10. """
  11. # 遍历sheet1中所有行row
  12. num_rows = worksheet1.nrows
  13. for curr_row in range(num_rows):
  14. row = worksheet1.row_values(curr_row)
  15. print('row%s is %s' %(curr_row,row))
  16. # 遍历sheet1中所有列col
  17. num_cols = worksheet1.ncols
  18. for curr_col in range(num_cols):
  19. col = worksheet1.col_values(curr_col)
  20. print('col%s is %s' %(curr_col,col))
  21. # 遍历sheet1中所有单元格cell
  22. for rown in range(num_rows):
  23. for coln in range(num_cols):
  24. cell = worksheet1.cell_value(rown,coln)
  25. print(cell)

2.使用 xlwt 来处理;

使用xlwt模块写入Excel文件

xlwt模块只能写xls文件,不能写xlsx文件(写xlsx程序不会报错,但最后文件无法直接打开,会报错)。

默认保存在py文件相同路径下,如果该路径下有相同文件,会被新创建的文件覆盖。

  1. import xlwt
  2. myWorkbook = xlwt.Workbook() # 创建Excel工作薄 若要写入中文则添加参数encoding = 'utf-8'
  3. sheet = myWorkbook.add_sheet('New_Sheet') # 创建Excel工作表
  4. ##sheet.write(m,n,'内容1') # 向单元格写入内容
  5. myStyle = xlwt.easyxf('font: name Times New Roman, color-index red, bold on', num_format_str='#,##0.00') # 数据格式
  6. sheet.write(1, 1, 2022, myStyle)
  7. sheet.write(2, 0, 1) # 写入A3,数值等于1
  8. sheet.write(2, 1, 1) # 写入B3,数值等于1
  9. sheet.write(2, 2, xlwt.Formula("A3+B3")) # 写入C3,数值等于2(A3+B3),xlwt支持写入公式
  10. # 保存
  11. myWorkbook.save('excelFile.xls')

示例:新建excel文件并写入数据

  1. import xlwt
  2. # 创建workbook和sheet对象
  3. workbook = xlwt.Workbook() # 注意Workbook的开头W要大写
  4. sheet1 = workbook.add_sheet('sheet1',cell_overwrite_ok=True)
  5. sheet2 = workbook.add_sheet('sheet2',cell_overwrite_ok=True)
  6. # 向sheet页中写入数据
  7. sheet1.write(0,0,'sheet1')
  8. sheet1.write(0,1,'sheet1_content')
  9. sheet2.write(0,0,'sheet2')
  10. sheet2.write(1,2,'sheet2_content')
  11. # 保存该excel文件,有同名文件时直接覆盖
  12. workbook.save('test.xls')
  13. print('创建excel文件完成!')

3.使用 openpyxl 来处理;

openpyxl可以对excel文件进行读写操作

openpyxl模块可实现对excel文件的读、写和修改,只能处理xlsx文件,不能处理xls文件。

  1. from openpyxl import Workbook
  2. from openpyxl import load_workbook
  3. from openpyxl.writer.excel import ExcelWriter
  4. wb = load_workbook(u"成绩单.xlsx")
  5. sheetnames = wb.sheetnames # 获得表单名字
  6. print(sheetnames)
  7. title = sheet1.title # 获取工作表名称
  8. rows = sheet1.max_row # 获取工作表行数
  9. cols = sheet1.max_column # 获取工作表列数
  10. sheet = wb[sheetnames[0]]
  11. print(sheet.cell(row=3,column=3).value)
  12. sheet['A1'] = 'grade'
  13. wb.save(u"成绩单_new.xlsx") # 修改元素值并另存为xlsx文件
  14. sheet = wb.active # 获取活动表
  15. print(sheet)
  16. print(sheet.dimensions) # 获取表格的尺寸大小
  17. cell1 = sheet['B7'] # 获取B7单元格的数据
  18. print(cell1.value) # cell1.value获取单元格B7中的值
  19. print(sheet['a2'].value) # 使用excel单元格的表示法,字母不区分大小写 获取第2行第1列的数据
  20. print(cell.value, cell.row, cell.column, cell.coordinate) # 获取某个格子的行数、列数以及坐标
  21. cell = sheet['A1:A5'] # 使用sheet['A1:A5']获取A1到A5的数据
  22. ##print(cell)
  23. # 打印A1到A5的数据
  24. for i in cell:
  25. for j in i:
  26. print(j.value)
  1. # openpyxl读取excel文件
  2. book = openpyxl.Workbook() # 创建工作簿 如果写入中文为乱码,可添加参数encoding = 'utf-8'
  3. sheet = book.create_sheet('Sheet_name',0) # 创建工作表,0表示创建的工作表在工作薄最前面
  4. sheet.cell(m,n,'content1') # 向单元格写入内容:
  5. book.save('excelFile') # 保存工作簿,默认保存在py文件相同路径下,如果该路径下有相同文件,会被新创建的文件覆盖。
  1. # openpyxl修改excel文件
  2. sheet.insert_rows(m)和sheet.insert_cols(n)分别表示在第m行、第n列前面插入行、列
  3. sheet.delete_rows(m)和sheet.delete_cols(n)分别表示删除第m行、第n列
  4. 修改单元格内容:sheet.cell(m,n) = '内容1'或者sheet['B3'] = '内容2'
  5. 在最后追加行:sheet.append(可迭代对象)

4.使用Pandas库来处理excel数据

Pandas 可以从各种文件格式比如 CSV、JSON、SQL、Microsoft Excel 导入数据。

  1. import pandas as pd
  2. mydata = {
  3. 'sites': ["SZ", "BJ", "SS"],
  4. 'number': [1, 2, 3]
  5. }
  6. myvar = pd.DataFrame(mydata)
  7. print(myvar)
  8. '''
  9. output:
  10. sites number
  11. 0 SZ 1
  12. 1 BJ 2
  13. 2 SS 3
  14. '''
  1. import pandas as pd
  2. file_path = r'example.xlsx'
  3. df = pd.read_excel(file_path, sheet_name = "test") # sheet_name不指定时默认返回全表数据
  4. print(df) # 打印表数据,如果数据太多,会略去中间部分
  5. print(df.head()) # 打印头部数据,仅查看数据示例时常用
  6. print(df.columns) # 打印列标题
  7. print(df.index) # 打印行
  8. print(df["ave"]) # 打印指定列
  9. # 描述数据
  10. print(df.describe())

写excel

  1. from pandas import DataFrame
  2. data = { 'name': ['zs', 'ls', 'ww'], 'age': [11, 12, 13], 'gender': ['man', 'man', 'woman']}
  3. df = DataFrame(data)
  4. df.to_excel('new.xlsx')

修改excel–以修改原Excel文件中gender列数据为例,把girl修改为female,boy修改为male:

  1. import pandas as pd
  2. from pandas import DataFrame
  3. file_path = r'test.xlsx'
  4. df = pd.read_excel(file_path)
  5. df['gender'][df['gender'] == 'girl'] = 'female'
  6. df['gender'][df['gender'] == 'boy'] = 'male'
  7. print(df)
  8. DataFrame(df).to_excel(file_path, sheet_name='Sheet1', index=False, header=True)
  9. df.loc[row_index] = [val1, val2, val3] # 新增行
  10. df[colo_name] = None # 新增列

示例1:读取excel数据

  1. # 导入pandas模块
  2. import pandas as pd
  3. # 直接默认读取到这个Excel的第一个表单
  4. sheet = pd.read_excel('test.xlsx')
  5. # 默认读取前5行数据
  6. data=sheet.head()
  7. print("获取到所有的值:\n{0}".format(data)) # 格式化输出
  8. # 也可以通过指定表单名来读取数据
  9. sheet2=pd.read_excel('test.xlsx',sheet_name='test')
  10. data2=sheet2.head() # 默认读取前5行数据
  11. print("获取到所有的值:\n{0}".format(data2)) # 格式化输出

示例2:操作Excel中的行列

  1. # 导入pandas模块
  2. import pandas as pd
  3. sheet=pd.read_excel('test.xlsx') # 这个会直接默认读取到这个Excel的第一个表单
  4. # 读取制定的某一行数据:
  5. data=sheet.loc[0].values # 0表示第一行 这里读取数据并不包含表头
  6. print("读取指定行的数据:\n{0}".format(data))
  7. # 读取指定的多行:
  8. data2=sheet.loc[[0,1]].values
  9. print("读取指定行的数据:\n{0}".format(data2))
  10. # 获取行号输出:
  11. print("输出行号列表",sheet.index.values)
  12. # 获取列名输出:
  13. print("输出列标题",sheet.columns.values)

其他

当收到的文件既有xls,又有xlsx时,先转换为统一格式再做统计修改更方便。

需要用到pywin32库,方法如下:

  1. import win32com.client as win32
  2. fname = r"C:\User\Desktop\test.xlsx"
  3. excel = win32.gencache.EnsureDispatch('Excel.Application')
  4. wb = excel.Workbooks.Open(fname)
  5. # wb.SaveAs(fname+"x", FileFormat = 51) #FileFormat = 51 is for .xlsx extension
  6. wb.SaveAs(fname[:-1], FileFormat = 56) #FileFormat = 56 is for .xls extension
  7. wb.Close()
  8. excel.Application.Quit()
文章知识点与官方知识档案匹配,可进一步学习相关知识
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/小小林熬夜学编程/article/detail/614661
推荐阅读
相关标签
  

闽ICP备14008679号