python学习笔记(八)python操作Excel
一、python操作excel,python操作excel使用xlrd、xlwt和xlutils模块,xlrd模块是读取excel的,xlwt模块是写excel的,xlutils是用来修改excel的。这几个模块使用pip安装即可,下面是这几个模块的使用。
二、xlwt模块,xlwt模块用来写一个新的Excel。

import xlwt
title = ['姓名','年龄','性别','分数']
stus = [['mary1',,'女',89.9],['mary2',,'女',89.9],['mary3',,'女',89.9],['mary4',,'女',89.9]]
book = xlwt.Workbook() #新建一个excel对象
sheet = book.add_sheet('stu') #添加一个名为stu的sheet页
for i in range(len(title)): #循环title
sheet.write(,i,title[i]) #将title中元素写入,作为表头
row=
for i in stus:
col =
for j in i:
sheet.write(row,col,j)
col+=
row+=
book.save('stu.xls')
三、导出数据库某个表中的数据到excel中
1.首先介绍函数enumerate([list1,list2,list3])的作用,这个函数在循环的时候可以直接获取到下标和值
来看看下面的例子就明白了
list = ['id','name','sex','addr','phone','score','gold']
for index ,value in enumerate(list):
print(index,value)
输出list的下标和元素值,输出结果如下
id
name
sex
addr
phone
score
gold
写一个通用的函数,从数据库中导出某个表的所有数据,只要你传入一个表名,就能把所有的数据导入出来,字段名是excel的表头
1、要动态获取到表的字段 cur.description能获取到表的字段
fileds = [ filed[0] for filed in cur.description ]
2、获取数据了 select * from "%s" % table_name
3、循环写入excel
import xlwt
def export_excel(table_name):
host, user, passwd, db = '118.24.3.40', 'jxz', '123456', 'jxz'
coon = pymysql.connect(host=host,user=user,passwd=passwd,db=db,port=3306,charset='utf8')
cur = coon.cursor() #建立游标,可以指定游标类型
sql = 'select * from %s'% table_name
cur.execute(sql)
fields = [field[0] for field in cur.description] #获取数据库表字段,存入列表fields中
all_data = cur.fetchall() #获取所有数据
book = xlwt.Workbook()
sheet = book.add_sheet('sheet1')
for col ,field in enumerate(fields): #循环写表头
sheet.write(0,col,field)
row =1 #从第一行开始写数据
for data in all_data:#all_data存的是所有数据,数据库中每一行数据是all_data中的一个元素,也就是循环数据库表中的每一行数据
for col,field in enumerate(data): #将每一行数据写入到excel中的某一行
sheet.write(row,col,field)
row+=1 #每写完一行,行数加1
book.save('%s.xls'%table_name)
四、读取excel中内容
import xlrd
book = xlrd.open_workbook('app_student.xls')#先用xlrd模块,打开一个excel
sheet = book.sheet_by_index()#根据索引获取sheet页
sheet = book.sheet_by_name('info')#根据sheet页名称获取sheet页
print(sheet.cell(,).value)#指定sheet页里的行和列获取数据
print(sheet.cell(,).value)#指定sheet页里的行和列获取数据
print(sheet.row_values())#获取到第1行的数据
print(sheet.row_values())#获取到第2行的数据
print(sheet.nrows)#获取excel中总共有多少行数据
print(sheet.ncols)#获取excel中总共有多少列
print(sheet.col_values())#获取第1列数据
for rownum in range(sheet.nrows):
print(sheet.row_values(rownum)) #取每行的数据
五、修改excel中内容
import xlrd
from xlutils import copy
book = xlrd.open_workbook('app_student.xls')#先用xlrd模块,打开一个excel
new_book = copy.copy(book)#通过xlutils这个模块里面copy方法,复制一份excel
sheet = new_book.get_sheet()#获取sheet页
lis = ['编号','名字','性别','年龄','地址','班级','手机号','金币']
for clo,filed in enumerate(lis): #获取list的下标和值,循环写入
sheet.write(,clo,filed)
new_book.save('app_student.xls')
python学习笔记(八)python操作Excel的更多相关文章
- python3.4学习笔记(八) Python第三方库安装与使用,包管理工具解惑
python3.4学习笔记(八) Python第三方库安装与使用,包管理工具解惑 许多人在安装Python第三方库的时候, 经常会为一个问题困扰:到底应该下载什么格式的文件?当我们点开下载页时, 一般 ...
- python 学习笔记八 进程和线程 (进阶篇)
什么是线程(thread)? 线程是操作系统能够进行运算调度的最小单位.它被包含在进程之中,是进程中的实际运作单位.一条线程指的是进程中一个单一顺序的控制流,一个进程中可以并发多个线程,每条线程并行执 ...
- Python学习笔记 - day12 - Python操作NoSQL
NoSQL(非关系型数据库) NoSQL,指的是非关系型的数据库.NoSQL有时也称作Not Only SQL的缩写,是对不同于传统的关系型数据库的数据库管理系统的统称.用于超大规模数据的存储.(例如 ...
- Python学习笔记_Mysql数据库、Excel
一.操作mysql数据库 import pymysql # 1.连上数据库:账号,密码,ip,端口号,数据库 # 2.建立游标(去数据库拿东西的工人) # 3.执行sql # 4.获取结果 # 5.关 ...
- python 学习笔记 9 -- Python强大的自省简析
1. 什么是自省? 自省就是自我评价.自我反省.自我批评.自我调控和自我教育,是孔子提出的一种自我道德修养的方法.他说:“见贤思齐焉,见不贤而内自省也.”(<论语·里仁>)当然,我们今天不 ...
- python学习笔记(一):python简介和入门
最近重新开始学习python,之前也自学过一段时间python,对python还算有点了解,本次重新认识python,也算当写一个小小的教程.一.什么是python?python是一种面向对象.解释型 ...
- python学习笔记(python介绍)
为什么要学python? python和shell的比较,和PHP.和JAVA比较 运维开发只是用到python的很小一部分 python在一些知名公司的应用: 谷歌:python的创始人原来在谷歌工 ...
- python学习笔记(python简史)
一.python介绍 python的创始人为吉多·范罗苏姆(Guido van Rossum) 目前python主要应用领域: ·云计算 ·WEB开发 ·科学运算.人工智能 ·系统运维 ·金融:量化交 ...
- python学习笔记:python字符串
二.python字符串操作符 1. 对象标准类型操作符 Python对象的标准类型操作符一共就三种:对象值的比较.对象身份的比较.布尔类型.其中对象值的比较主要是大于.小于.不等于等的数学比较符:对象 ...
- python 学习笔记一——Python安装和IDLE使用
好吧,一直准备学点啥,前些日子也下好了一些python电子书,但之后又没影了.年龄大了,就是不爱学习了.那就现在开始吧. 安装python 3 Mac OS X会预装python 2,Linux的大多 ...
随机推荐
- 手把手教你利用微软的Bot Framework,LUIS,QnA Maker做一个简单的对话机器人
最近由于要参加微软亚洲研究院的夏令营,需要利用微软的服务搭建一个对话Bot,以便对俱乐部的情况进行介绍,所以现学了几天,搭建了一个简单的对话Bot,期间参考了大量的资料,尤其是下面的这篇博客: htt ...
- C#实例.net_经典例子400个
一共470多例winform 界面特效的源码. 窗体与界面设计... 9 实例001 带历史信息的菜单 10 实例002 菜单动态合并 12 实例003 像开始菜单一样漂亮的菜单.. ...
- ThinkPHP种where的使用(_logic and _complex)的使用实例
1.对于thinkphp中的 and ,or 等复合型的查询,我要正确的使用相关的方法. a.实例 b.实例
- hdu 4685(匹配+强连通分量)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4685 思路:想了好久,终于想明白了,懒得写了,直接copy大牛的思路了,写的非常好! 做法是先求一次最 ...
- IOS 开发之 -- 获取本机通讯录里面所有的联系人,并传到后台
项目中遇到一个需求,就是需要在入口的时候,获取通讯录的权限,并把所有的联系人,以接口参数的形式传到后台,通过网上查资料,历时3个小时,终于完成, 话不多,直接上代码: 1,导入系统库 #import ...
- 用Broadcast Receiver刷新数据
①注册广播事件: 注册方式有两种, 一种是静态注册,就是在AndroidManifest.xml文件中定义,注册的广播接收器必须要继承BroadcastReceiver: 另一种是动态注册,是在程序中 ...
- PHP后台代码解决跨域问题
在前端里面,解决跨域的时候总显得那么的恶心,什么jsonp啊,ajax啊,CORS啊什么的,总觉得是在钻空子进行跨域,其实在PHP文件里面只需要加一段代码就可以跨域了,前端你该怎么写还是怎么写,p ...
- [Android] 开源框架 Volley 自定义 Request
今天在看Volley demo (https://github.com/smanikandan14/Volley-demo), 发现自定义GsonRequest那块代码不全, 在这里贴一个全的. pu ...
- HYSBZ 2243(染色)
题目链接:传送门 题目大意:中文题,略 题目思路:树链剖分,区间更新,区间查询. 闲谈: 只想说这道题做的好苦逼..去长春现场赛之前就没A,回来后又做了2天才A掉,蒟蒻太菜了 这道题也没有想 ...
- 【BZOJ4881】5月月赛D 线段游戏 树状数组+set
Description quailty和tangjz正在玩一个关于线段的游戏.在平面上有n条线段,编号依次为1到n.其中第i条线段的两端点坐 标分别为(0,i)和(1,p_i),其中p_1,p_2,. ...