iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > Python >在python中如何导出数据到Excel
  • 105
分享到

在python中如何导出数据到Excel

2024-04-02 19:04:59 105人浏览 泡泡鱼

Python 官方文档:入门教程 => 点击学习

摘要

本篇内容介绍了“在python中如何导出数据到excel”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!问题

本篇内容介绍了“在python中如何导出数据到excel”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

问题描述

为了更好地展示数据,Excel格式的数据文件往往比文本文件更具有优势,但是具体到Python中,该如何导出数据到Excel呢?如果碰到需要导出大量数据又该如何操作呢?

具体步骤

Step 1 安装openpyxl

使用 pip install openpyxl  即可,但是在windows下安装的是2.2.6版本,在Centos自动安装的是4.1版本,写的代码在windows下运行没问题,但centos上却报错了,说是ew=ExcelWriter(workbook=wb)少提供一个参数,于是果断在  237服务器上我已安装2.2.6版本的,问题解决。

pip install openpyxl==2.2.6

Step 2 直接上代码(Ps:代码中包含xlwt和openpyxl的两个实现版本)

coding:utf-8 ''' # 希望对大家有帮助哈,请多提问题 create by yaoyz date: 2017/01/24 ''' importxlrd importxlwt # workbook相关 fromopenpyxl.workbookimportWorkbook # ExcelWriter,封装了很强大的excel写的功能 fromopenpyxl.writer.excelimportExcelWriter # 一个eggache的数字转为列字母的方法 fromopenpyxl.utilsimportget_column_letter fromopenpyxl.reader.excelimportload_workbook classhandleExcel(): '''Excel相关操作类''' def__init__(self): self. head_row_labels = [u'学生ID',u'学生姓名',u'联系方式',u'知识点ID',u'知识点名称'] """         function:             读出txt文件中的每一条记录,把它保存在list中         Param:             filename:  要读出的文件名         Return:             res_list:返回的记录的list     """ defread_from_file(self,filename):         res_list=[] file_obj=open(filename,"r") forlineinfile_obj.readlines():             res_list.append(line)         file_obj.close() returnres_list """         function:             读出*.xlsx中的每一条记录,把它保存在data_dic中返回         Param:             excel_name:  要读出的文件名         Return:             data_dic:返回的记录的dict     """ defread_excel_with_openpyxl(self, excel_name="testexcel2007.xlsx"): # 读取excel2007文件         wb = load_workbook(filename=excel_name) # 显示有多少张表 print"Worksheet range(s):", wb.get_named_ranges() print"Worksheet name(s):", wb.get_sheet_names() # 取第一张表         sheetnames = wb.get_sheet_names() ws = wb.get_sheet_by_name(sheetnames[0]) # 显示表名,表行数,表列数 print"Work Sheet Titile:",ws.title print"Work Sheet Rows:",ws.get_highest_row() print"Work Sheet Cols:",ws.get_highest_column() # 获取读入的excel表格的有多少行,有多少列         row_num=ws.get_highest_row()         col_num=ws.get_highest_column() print"row_num: ",row_num," col_num: ",col_num # 建立存储数据的字典         data_dic = {} sign=1 # 把数据存到字典中 forrowinws.rows:             temp_list=[] # print "row",row forcellinrow: printcell.value,                 temp_list.append(cell.value) print""             data_dic[sign]=temp_list sign+=1 printdata_dic returndata_dic """         function:             读出*.xlsx中的每一条记录,把它保存在data_dic中返回         Param:             records: 要保存的,一个包含每一条记录的list             save_excel_name:  保存为的文件名             head_row_stu_arrive_star:         Return:             data_dic:返回的记录的dict     """ defwrite_to_excel_with_openpyxl(self,records,head_row,save_excel_name="save.xlsx"): # 新建一个workbook         wb = Workbook() # 新建一个excelWriter         ew = ExcelWriter(workbook=wb) # 设置文件输出路径与名称 dest_filename = save_excel_name.decode('utf-8') # 第一个sheet是ws ws = wb.worksheets[0] # 设置ws的名称 ws.title ="range names" # 写第一行,标题行 forh_xinrange(1,len(head_row)+1):             h_col=get_column_letter(h_x) #print h_col ws.cell('%s%s'% (h_col,1)).value ='%s'% (head_row[h_x-1]) # 写第二行及其以后的那些行 i =2 forrecordinrecords: record_list=str(record).strip().split("\t") forxinrange(1,len(record_list)+1):                 col = get_column_letter(x) ws.cell('%s%s'% (col, i)).value ='%s'% (record_list[x-1].decode('utf-8')) i +=1 # 写文件         ew.save(filename=dest_filename) """         function:             测试输出Excel内容             读出Excel文件         Param:             excel_name:  要读出的Excel文件名         Return:           无     """ defread_excel(self,excel_name):         workbook=xlrd.open_workbook(excel_name) printworkbook.sheet_names() # 获取所有sheet printworkbook.sheet_names()# [u'sheet1', u'sheet2'] sheet2_name = workbook.sheet_names()[1] # 根据sheet索引或者名称获取sheet内容 sheet2 = workbook.sheet_by_index(1)# sheet索引从0开始 sheet2 = workbook.sheet_by_name('Sheet1') # sheet的名称,行数,列数 printsheet2.name,sheet2.nrows,sheet2.ncols # 获取整行和整列的值(数组) rows = sheet2.row_values(3)# 获取第四行内容 cols = sheet2.col_values(2)# 获取第三列内容 printrows printcols # 获取单元格内容 printsheet2.cell(1,0).value printsheet2.cell_value(1,0) printsheet2.row(1)[0].value # 获取单元格内容的数据类型 printsheet2.cell(1,0).ctype # 通过名称获取 returnworkbook.sheet_by_name(u'Sheet1') """         function:             设置单元格样式         Param:             name:  字体名字             height:  字体高度             bold:  是否大写         Return:             style: 返回设置好的格式对象     """ defset_style(self,name,height,bold=False): style = xlwt.XFStyle()# 初始化样式 font = xlwt.Font()# 为样式创建字体 font.name = name# 'Times New Roman'         font.bold = bold font.color_index =4         font.height = height         borders= xlwt.Borders() borders.left=6 borders.right=6 borders.top=6 borders.bottom=6         style.font = font         style.borders = borders returnstyle """         function:             按照 设置单元格样式  把计算结果由txt转变为Excel存储         Param:             dataset:要保存的结果数据,list存储         Return:             将结果保存为 excel对象中     """ defwrite_to_excel(self, dataset,save_excel_name,head_row): f = xlwt.Workbook()# 创建工作簿 # 创建第一个sheet: # sheet1 count=1 sheet1 = f.add_sheet(u'sheet1', cell_overwrite_ok=True)# 创建sheet # 首行标题: forpinrange(len(head_row)): sheet1.write(0,p,head_row[p],self.set_style('Times New Roman',250,True)) default=self.set_style('Times New Roman',200,False)# define style out the loop will work forlineindataset: row_list=str(line).strip("\n").split("\t") forppinrange(len(str(line).strip("\n").split("\t"))): sheet1.write(count,pp,row_list[pp].decode('utf-8'),default) count+=1 f.save(save_excel_name)# 保存文件 defrun_main_save_to_excel_with_openpyxl(self): print"测试读写2007及以后的excel文件xlsx,以方便写入文件更多数据" print"1. 把txt文件读入到内存中,以list对象存储" dataset_list=self.read_from_file("test_excel.txt") '''test use openpyxl to handle EXCEL 2007''' print"2. 把文件写入到Excel表格中"         head_row_label=self.head_row_labels save_name="test_openpyxl.xlsx"         self.write_to_excel_with_openpyxl(dataset_list,head_row_label,save_name) print"3.  执行完毕,由txt格式文件保存为Excel文件的任务" defrun_main_save_to_excel_with_xlwt(self): print" 4. 把txt文件读入到内存中,以list对象存储" dataset_list=self.read_from_file("test_excel.txt") '''test use xlwt to handle EXCEL 97-2003''' print" 5. 把文件写入到Excel表格中"         head_row_label=self.head_row_labels save_name="test_xlwt.xls"         self.write_to_excel_with_openpyxl(dataset_list,head_row_label,save_name) print"6.  执行完毕,由txt格式文件保存为Excel文件的任务" if__name__ =='__main__': print"create handle Excel Object"     obj_handle_excel=HandleExcel() # 分别使用openpyxl和xlwt将数据写入文件     obj_handle_excel.run_main_save_to_excel_with_openpyxl()     obj_handle_excel.run_main_save_to_excel_with_xlwt() '''测试读出文件,注意openpyxl不可以读取xls的文件,xlrd不可以读取xlsx格式的文件''' #obj_handle_excel.read_excel_with_openpyxl("testexcel2003.xls")  # 错误写法 #obj_handle_excel.read_excel_with_openpyxl("testexcel2003.xls") # 错误写法 obj_handle_excel.read_excel("testexcel2003.xls") obj_handle_excel.read_excel_with_openpyxl("testexcel2007.xlsx")

“在python中如何导出数据到Excel”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!

--结束END--

本文标题: 在python中如何导出数据到Excel

本文链接: https://www.lsjlt.com/news/83299.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 在python中如何导出数据到Excel
    本篇内容介绍了“在python中如何导出数据到Excel”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!问题...
    99+
    2024-04-02
  • python pandas库导出数据到excel
    利用pandas库导出数据到excel,代码如下 import pandas as pd# 数据格式1,字典形式mydic = { '姓名': ['张三', '李四', '王五'], '年龄': [18, 20, 22] ...
    99+
    2023-10-05
    python pandas excel
  • 如何在Python中导入EXCEL数据
    目录一、前期准备二、编写代码基本思路三、编写代码读取数据3.1  3.2四、结语一、前期准备      &nbs...
    99+
    2023-03-22
    python处理excel Python导入EXCEL
  • Java导出数据到Excel
    Java导出数据到Excel分3步处理 1、构建Workbook 数据 2、设置Workbook 格式 3、导出到Excel 1、构建Workbook 数据 public static void b...
    99+
    2023-09-04
    java excel 开发语言
  • 如何从Mysql中导出数据到excel文件中
    这篇文章给大家介绍如何从Mysql中导出数据到excel文件中,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。 每次通过int...
    99+
    2024-04-02
  • JS如何实现将数据导出到Excel
    今天小编给大家分享一下JS如何实现将数据导出到Excel的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。方法一:将table标...
    99+
    2023-07-02
  • 【python】导出mysql数据,输出excel!
    今天来说说,如果想要导出数据库里面的数据,并生成excel表格,该怎么操作,比较简单! 一.环境配置 这边需要安装pandas、pymysql、openpyxl三个库 os库 循环遍历安装所有库: ##想要安装的库的列表libs = ["...
    99+
    2023-09-05
    pandas openpyxl pymysql
  • Python数据处理-导入导出excel数据
    目录一.xlwt库将数据导入Excel1.将数据写入一个Excel文件2.定制Excel表格样式3.元格对齐4.单元格的背景色5.单元格边框二、xlrd库读取Excel中的数据1.读...
    99+
    2024-04-02
  • 在 PHP 中将 MySQL 表导出到 Excel
    我们将在本文中看到如何使用 PHP 将 MySQL 中的表导出到 excel 中。 在 PHP 中将 MySQL 表导出到 Excel 我们可以使用 PHP 中的 excel 标头将 MySQ...
    99+
    2024-02-27
  • python 如何导入excel数据
    你可以使用`pandas`库来导入Excel数据。下面是一个示例: ```pythonimport pandas as pd# 读取Excel文件data = pd.read_excel('data.xlsx')# 打印前几行数据print...
    99+
    2023-10-26
    python excel 开发语言
  • C#中如何使用NPOI将List数据导出到Excel文档
    今天小编给大家分享一下C#中如何使用NPOI将List数据导出到Excel文档的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。...
    99+
    2023-06-29
  • Python将数据库数据导入到EXCEL
          每次给运营导数据的时候,如果不用工具的话,就是直接生成.csv格式的文件,这样的文件不支持'sheet',每次还有手工进行,相当的不科学,今天试试Python生成excel文件。        写的糙了点,但是这是一个很好的开始...
    99+
    2023-01-31
    导入到 数据库 数据
  • Java中用POI实现将数据导出到Excel
    一、前言 数据导出为Excel在我们写项目的过程中经常用到 需要用到的jar包 poi-3.17.jar 二、具体实现步骤 //第一步创建一个webbook,对应一个Excel...
    99+
    2024-04-02
  • 如何在Oracle中导入导出数据
    今天就跟大家聊聊有关如何在Oracle中导入导出数据,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。1.导出dmp格式文件--备份某几张表 ...
    99+
    2024-04-02
  • 如何利用Excel导入数据到SAP C4C中
    这篇文章主要介绍“如何利用Excel导入数据到SAP C4C中”,在日常操作中,相信很多人在如何利用Excel导入数据到SAP C4C中问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”如何利用Excel导入数据...
    99+
    2023-06-04
  • php如何不用三方类库导出MySQL数据到Excel
    这篇文章主要为大家展示了“php如何不用三方类库导出MySQL数据到Excel”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“php如何不用三方类库导出MySQL...
    99+
    2024-04-02
  • jxl 导出数据到excel的实例讲解
    优点:Jxl对中文支持非常好,操作简单,方法看名知意。Jxl是纯javaAPI,在跨平台上表现的非常完美,代码可以再windows或者Linux上运行而无需重新编写支持Excel 95-2000的所有版本(网上说目前可以支持Excel200...
    99+
    2023-05-30
    jxl 导出 excel
  • mysql数据库表导出到excel的方法
    mysql数据库表导出到excel的方法?这个问题可能是我们日常学习或工作经常见到的。希望通过这个问题能让你收获颇深。下面是小编给大家带来的参考内容,让我们一起来看看吧!mysql数据库表导出到excel的...
    99+
    2024-04-02
  • 在SQLite中如何导入和导出数据
    要在SQLite中导入数据,可以使用以下方法之一: 使用SQLite的命令行工具,将数据文件导入到数据库中。可以使用以下命令: ...
    99+
    2024-04-09
    SQLite
  • 在MongoDB中如何导出和导入数据
    要在MongoDB中导出数据,可以使用mongoexport命令。下面是一个示例: mongoexport --db <数据库...
    99+
    2024-04-20
    MongoDB
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作