xlwt教程地址  ----_<_>_----

概述

Openpyxl是python中简单易用的操作excel电子表格的一个模块。接下来呢,跟博主一起学习一下吧  ----_<_>_----

首先先清楚一些excel的基本概念:

在openpyxl中,主要用到三个概念:Workbooks,Sheets,Cells。Workbook就是一个excel工作表;Sheet是工作表中的一张表页;Cell就是简单的一个格。openpyxl就是围绕着这三个概念进行的,不管读写都是“三板斧”:打开Workbook,定位Sheet,操作Cell。

总结:

  • workbooks是excel一个工作表,一个工作表包含多个页,即包含多个sheet
  • sheet是excel当中的一页,一个工作页包含多个表格,即包含多个cell
  • cell是excel当中的一个工作表格

安装

  1. pip install openpyxl

接下来就介绍一下简单的操作

  

  1. # -*- coding:utf-8 -*-
  2.  
  3. # 导入
  4. from openpyxl import workbook
  5. from openpyxl import load_workbook
  6.  
  7. # 打开一个供作薄
  8. wb = load_workbook('file_name.xlsx')
  9.  
  10. # 获取一张表
  11. sheet = wb.get_sheet_by_name("Sheet1")
  12. # 获取A1格的值
  13. print sheet['A1'].value
  14. # 获取表的最大工作行数
  15. print sheet.max_row
  16. # 获取表的最大工作列数
  17. print sheet.max_column
  18. # 打印C列的所有内容(以下格式代表不换行)
  19. for i in sheet["C"]:
  20. print i.value, ' ',
  21. print ''
  22. # 打印1行的所有内容
  23. for i in sheet["1"]:
  24. print i.value, ' ',
  25. print ''

  注意:当读到的内容为None时说明该表格中的内容为空

接下来呢新创建一个新的工作薄

  1. # -*- coding:utf-8 -*-
  2.  
  3. from openpyxl import Workbook
  4.  
  5. # 创建一个工作薄
  6. wb = Workbook()
  7.  
  8. # 创建一个工作表(注意是一个属性)
  9. sheet = wb.active
  10.  
  11. # excel创建的工作表名默认为sheet1,一下代码实现了给新创建的工作表创建一个新的名字
  12. sheet.title = 'create_sheet'
  13.  
  14. # 向工作表中输入内容
  15. sheet['C3'] = 'hello word'
  16.  
  17. for i in range(10):
  18. sheet['A%d' % (i+1)] = i+1
  19.  
  20. # 向excel表中输入表达试
  21. sheet['C2'] = '=SUM(A:A)'
  22.  
  23. # 保存一个文档
  24. wb.save('create_excel.xlsx')
  25.  
  26. if __name__ == '__main__':
  27. pass

  保存之后会出现一下样式

django中从服务端弹到浏览器段的方法

思想:将信息保存到字符串缓冲区,然后指定返回到客户端的格式为excel格式即可

代码:

  1. from openpyxl import load_workbook
  2.  
  3. wb = load_workbook('file_name.xlsx')
  4.  
  5. from io import BytesIO
  6.  
  7. output = BytesIO()
  8.  
  9. sheet = wb[wb.get_sheet_names()[0]] # 获取第一个工作区
  10.  
  11. sheet['A3'] = 'kayb'
  12.  
  13. wb.save(output) # 将wb文件保存到缓存区中
  14.  
  15. response = HttpResponse(content_type='application/vnd.ms-excel')
  16. response['Content-Disposition'] = 'attachment;filename={0}.xlsx'.format(‘file_name’)
  17. response.write(output.getvalue()) # 获取缓冲区当中的值
  18. return response

  

python中openpyxl的用法【安装,以及一些基本的操作】的更多相关文章

  1. python中MySQLdb模块用法实例

    篇文章主要介绍了python中MySQLdb模块用法,以实例形式详细讲述了MySQLdb模块针对MySQL数据库的各种常见操作方法,非常具有实用价值,需要的朋友可以参考下 本文实例讲述了python中 ...

  2. python 中del 的用法

    python中的del用法比较特殊,新手学习往往产生误解,弄清del的用法,可以帮助深入理解python的内存方面的问题. python的del不同于C的free和C++的delete. 由于pyth ...

  3. python中argparse模块用法实例详解

    python中argparse模块用法实例详解 这篇文章主要介绍了python中argparse模块用法,以实例形式较为详细的分析了argparse模块解析命令行参数的使用技巧,需要的朋友可以参考下 ...

  4. 【313】python 中 print 函数用法总结

    参考:python 中 print 函数用法总结 参考:Python print() 函数(菜鸟教程) 参考:Python 3 print 函数用法总结 目录: 字符串和数值类型 变量 格式化输出 p ...

  5. python中hashlib模块用法示例

    python中hashlib模块用法示例 我们以前介绍过一篇Python加密的文章:Python 加密的实例详解.今天我们看看python中hashlib模块用法示例,具体如下. hashlib ha ...

  6. Python Deque 模块使用详解,python中yield的用法详解

    Deque模块是Python标准库collections中的一项. 它提供了两端都可以操作的序列, 这意味着, 你可以在序列前后都执行添加或删除. https://blog.csdn.net/qq_3 ...

  7. Python中super的用法【转载】

    Python中super的用法[转载] 转载dxk_093812 最后发布于2019-02-17 20:12:18 阅读数 1143  收藏 展开 转载自 Python面向对象中super用法与MRO ...

  8. python中的有趣用法

    本文给除了python中几个有趣的用法,可以给我们不一样的启发 1: Python中模拟使用C++ 中的   cout << import sys  class ostream: def  ...

  9. Python中With的用法

    在看Dive Into Python中有关描述文件读写那章节的时候,看到了有关with的用法,查阅下相关资料,记录下来,以备后用. 官方的reference上有关with statement是这样说的 ...

随机推荐

  1. 【Socket编程】通过Socket实现UDP编程

    通过Socket实现UDP编程 UDP通信: 1.UDP协议(用户数据报协议)是无连接.不可靠.无序的. 2.UDP协议以数据报作为数据传输的载体. 3.使用UDP进行数据传输时,首先需要将要传输的数 ...

  2. 巧用 BootStrap --- 栅格系统(布局)轻松搞定网页响应式布局!

    摘要:Bootstrap 为我们提供了一套响应式.移动设备优先的流式栅格系统,合理的使用栅格系统将会使得网站页面布局变得更加简单,在设置了媒体查询之后,响应式网站也无需再单独写了.接下来我以Boots ...

  3. POJ-3045 Cow Acrobats (C++ 贪心)

    Description Farmer John's N (1 <= N <= 50,000) cows (numbered 1..N) are planning to run away a ...

  4. Qt--自定义View

    这是上一篇文章的续篇,关于自定义View. 多个View内部可以映射到同一个数据模型,也可以映射不同的数据结构:可以使用所有数据,也可以只使用部分数据.因为视图层与数据层的分离,操作相对比较灵活. 1 ...

  5. java中Set类接口的用法

    在Java中使用Set,可以方便地将需要的类型,以集合类型保存在一个变量中.主要应用在显示列表. Set是一个不包含重复元素的collection.更确切地讲,set 不包含满足 e1.equals( ...

  6. 【京东账户】——Mysql/PHP/Ajax爬坑之页头页尾加载

    一.引言 实现京东的账户项目,有一个小功能,页头页尾加载.要用到的是Apach环境,Mysql.PHP以及Ajax. 二.实现 原理: 用php文件分别写一个的页头和一个页尾,放在前后两个div里. ...

  7. LINUX通过PXE自动部署系统

    原理介绍 TFTP(Trivial File Transfer Protocol,简单文件传输协议)是TCP/IP 协议族中的一个用来在客户机与服务器之间进行简单文件传输的协议,提供不复杂.开销不大的 ...

  8. TCP/IP(四)网络层

    前言 前面给大家介绍了计算机网络的基本概述,物理层和数据链路层.这一篇给大家介绍面试中经常会被问到的网络层.在介绍之前我们回顾一下之前学习的知识! CP/IP协议栈:物理层.链路层.网络层.传输层.应 ...

  9. 移植u-boot-2012.04.01到JZ2440

    开发环境:Ubuntu 12.04 开发板:JZ2440  256M NandFlash  64M SDRAM 交叉编译器:arm-linux-gcc-4.3.2 u-boot:u-boot-2012 ...

  10. Java并发/多线程系列——线程安全篇(1)

    创建和启动Java线程 Java线程是个对象,和其他任何的Java对象一样.线程是类的实例java.lang.Thread,或该类的子类的实例.除了对象之外,java线程还可以执行代码. 创建和启动线 ...