安装xlrd模块和xlwt模块

读取Excel文件了内容需要额外的模块—— \(xlrd\),在官网上可以找到下载:https://pypi.python.org/pypi/xlrd#downloads

下载完毕后解压到当前文件夹,点击进入,可以找到一个 setup.py 文件,在当前目录下打开 cmd 窗口,运行“python setup.py install”(需要提前将python添加环境变量),成功后,去Python Shell中运行“import xlrd”试一下,应该没什么问题。解压得到的xlrd模块文件都可以删除。

另外,如果你使用PyCharm的话,那就更好办了,点击"File" -> "Settings" -> "Project interpreter" -> "+" -> 查找"xlrd" -> "install package",OK了。

同样的,写入Excel文件需要的是 \(xlwt\) 模块,方法类似,就不多解释了。下载地址:https://pypi.python.org/pypi/xlwt

读取Excel文件

不得不说,这个模块简单易懂,容易上手,几分钟就会了。直接看代码如何使用吧!

  1. class myExcel(object):
  2. def __init__(self, excelPath):
  3. self.path = excelPath
  4. def readExcel(self):
  5. excel = xlrd.open_workbook(self.path)
  6. # get sheet names
  7. print(excel.sheet_names())
  8. # get sheet content(By index or By name)
  9. sheet = excel.sheet_by_index(0)
  10. sheet1 = excel.sheet_by_name("Sheet1")
  11. sheet2 = excel.sheets()[0]
  12. # get sheet info
  13. print(sheet.name, sheet.nrows, sheet.ncols)
  14. # get row/col content
  15. row = sheet.row_values(0)
  16. col = sheet.col_values(0)
  17. print(row, col)
  18. # get cell value
  19. cell = sheet.cell(0, 0)
  20. print(cell.value)
  21. print(sheet.cell_value(0, 0))
  22. print(sheet.row(0)[0].value)
  23. # get cell ctype:0empty 1string 2number 3date 4boolean 5error
  24. print(sheet.cell(0, 0).ctype)
  25. return excel
  26. def printExcel(self):
  27. excel = self.readExcel()
  28. sheet = excel.sheets()[0]
  29. for i in range(0, sheet.nrows):
  30. row = sheet.row_values(i)
  31. for item in row:
  32. print(item, '|')

写入Excel文件

这个也还行,单纯的加入数据还是挺简单的。

发现了一个问题,这个xlwt模块只能保存为".xls"表格,有点绝望。

稍微查了一下,果然存在可以保存为".xlsx"表格的模块,叫做 \(openpyxl\),请参考:https://www.cnblogs.com/anpengapple/p/6399304.html?utm_source=itdadao&utm_medium=referral

  1. def writeOneRow(self, sheet, nrow, rowList):
  2. # 格式:{单元格:背景黄色;字体:红色粗体}
  3. style = xlwt.easyxf('pattern: pattern solid, fore_colour yellow;font: bold 0, color red;')
  4. ncol = 0
  5. for row in rowList:
  6. sheet.write(nrow, ncol, row, style)
  7. ncol += 1
  8. def writeExcel(self, excelName):
  9. # create a Excel and add sheet
  10. excel = xlwt.Workbook()
  11. sheet = excel.add_sheet('sheet1', cell_overwrite_ok=True)
  12. headList = ['Stu_id', 'name', 'sex']
  13. data = [['1', 'stu1', '男'],
  14. ['2', 'stu2', '男'],
  15. ['3', 'stu3', '女'],]
  16. self.writeOneRow(sheet, 0, headList)
  17. for nrow in range(0, 3):
  18. self.writeOneRow(sheet, nrow, data[nrow])
  19. excel.save(excelName)

Excel转换成Markdown格式

其实这是我做这个小练习的主要原因,由于随笔都是用Markdowm格式写的,有一篇随笔是LeetCode所有题目的列表:

LeetCode All in One题解汇总(持续更新中...)。我才不想一条一条加呢!稍微转换一下,添加点格式符号就OK了。

  1. def toMarkdown(self, mdName):
  2. excel = self.readExcel()
  3. sheet = excel.sheets()[0]
  4. file = open(mdName, 'w', encoding='utf-8')
  5. rowStr = "| %d | [%s]() | %.3f | '%s' |\n"
  6. try:
  7. file.write('| 编号 | 题名 | 过题率 | 难度 |' + '\n')
  8. file.write('| :------------: |:---------------: | :------------:| :-----:|' + '\n')
  9. for i in range(0, sheet.nrows):
  10. row = sheet.row_values(i)
  11. data = rowStr % (int(row[0]), str(row[1]), float(row[2]), str(row[3]))
  12. file.write(data)
  13. print('成功写入文件,共有%d条记录...' % sheet.nrows)
  14. except Exception as e:
  15. print(e)
  16. finally:
  17. file.close()

完整代码:https://github.com/Pacsiy/learnPY/tree/master/LeetCodeAllProblem


本文版权归作者AlvinZH和博客园所有,欢迎转载和商用,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利.


Python小实验——读&写Excel文件内容的更多相关文章

  1. openpyxl -用于读/写Excel 2010 XLSX/XLSM文件的python库

    openpyxl -用于读/写Excel 2010 XLSX/XLSM文件的python库¶ https://www.osgeo.cn/openpyxl/index.html

  2. 使用Python xlwt写excel文件

    如果需要使用Python写Excel文件,首先下载或者安装xlwt. pip install xlwt 下面的这些demo应该可以帮助开发者快速上手使用xlwt写Excel文件: 创建工作簿(work ...

  3. Pandas 基础(4) - 读/写 Excel 和 CSV 文件

    这一节将分别介绍读/写 Excel 和 CSV 文件的各种方式: - 读入 CSV 文件 首先是准备一个 csv 文件, 这里我用的是 stock_data.csv, 文件我已上传, 大家可以直接下载 ...

  4. 第15.25节 PyQt(Python+Qt)入门学习:Model/View开发实战--使用QTableView展示Excel文件内容

    老猿Python博文目录 专栏:使用PyQt开发图形界面Python应用 老猿Python博客地址 一.概述 在前面的订阅专栏<第十九章.Model/View开发:QTableView的功能及属 ...

  5. 基于Python的接口自动化-读写excel文件

    引言 使用python进行接口测试时常常需要接口用例测试数据.断言接口功能.验证接口响应状态等,如果大量的接口测试用例脚本都将接口测试用例数据写在脚本文件中,这样写出来整个接口测试用例脚本代码将看起来 ...

  6. Java使用jxl.jar包写Excel文件的最适合列宽问题基本实现

    以前用jxl.jar包,读写过Excel文件.也没有注意最适合列宽的问题,但是jxl.jar没有提供最适合列宽的功能,上次用到写了一下,可以基本实现最适合列宽. 注意,这个只是基本可以实现,基本针对中 ...

  7. 用Python的pandas框架操作Excel文件中的数据教程

    用Python的pandas框架操作Excel文件中的数据教程 本文的目的,是向您展示如何使用pandas 来执行一些常见的Excel任务.有些例子比较琐碎,但我觉得展示这些简单的东西与那些你可以在其 ...

  8. JXL包大解析;Java程序生成excel文件和解析excel文件内容

    最近需求变化,需要把excel导入 我以前没有做过,所以我查了一些资料 和参考别人的代码 以下是多种方式: import java.io.File; import java.io.FileInputS ...

  9. java对excel文件内容读写修改操作

    Read.java package domain; import java.io.FileInputStream; import java.io.InputStream; import jxl.Cel ...

随机推荐

  1. 39-python 字符串替换+正则

    from bs4 import BeautifulSoup import urllib.request import re moduel =re.compile('<.*?>') st = ...

  2. Golang笔记之变量

    哈哈 package main // 关键字var 声明变量 类型信息放在变量名后 //声明一个int型变量 var v1 int //声明一个string类型 var v2 string //声明多 ...

  3. oracle 分页其实一个子查询就好了,没理解的自然只能见样学样

    .首先rownum是一个查询缓存级别的东西,所以以下写法是错误的 ; 因为rn其实不是student表的内容,看做一个缓存编号就好 但是有些人不服了,加个a.rn<= ;结果还是不行,这下相信了 ...

  4. W-D-S-Nandflash

    1.6410的硬件一上电就会把nandflash前8K的内容拷贝到6410片内内存来,从片内内存0地址开始运行,如果烧写到nandflash里面的程序大于8k,则拷贝到6410片内的8k程序要把nan ...

  5. Adobe Photoshop CC 2015安装激活教程

    Adobe Photoshop CC 2015安装激活教程(附序列号) Adobe Photoshop CC 2015是Adobe针对旗下的创意云Creative Cloud 套装推出了2015年年度 ...

  6. 1 web应用-http协议-web框架

    web 应用 Web 应用程序是一种可以通过 Web 访问的应用程序,程序的最大好处是用户很容易访问应用程序,用户只需要有浏览器即可,不需要再安装其他软件.应用程序有两种模式 C/S.B/S.C/S ...

  7. ETL的测试

    二.ETL测试过程: 在独立验证与确认下,与任何其他测试一样,ETL也经历同样的阶段. 1)业务和需求分析并验证. 2)测试方案编写 3)从所有可用的输入条件来设计测试用例和测试场景进行测试 4)执行 ...

  8. POJ 3977 Subset(折半枚举+二分)

    SubsetTime Limit: 30000MS        Memory Limit: 65536KTotal Submissions: 6754        Accepted: 1277 D ...

  9. spring获取webapplicationcontext,applicationcontext几种方法详解(转载)

    转载自  http://www.blogjava.net/Todd/archive/2010/04/22/295112.html 方法一:在初始化时保存ApplicationContext对象 代码: ...

  10. linux下文件打包、压缩详解

    Linux平台下,有如下几种常见的压缩工具: ========================================================================= 工 具 ...