一、操作mysql数据库

import pymysql

# 1.连上数据库:账号,密码,ip,端口号,数据库

# 2.建立游标(去数据库拿东西的工人)

# 3.执行sql

# 4.获取结果

# 5.关闭游标

# 6.连接关闭

coon = pymysql.connect(

host='xxx.xxx.xxx.xxx',user='xxx',passwd='123456',port=3306,db='xxx',charset='utf8')  ##port必须是int类型,charset必须是utf8,而不是utf-8

cur = coon.cursor()  #建立游标

cur.execute('select * from stu;')

cur.execute('insert into stu (id,name,sex) value (33,"6j","女")')

coon.commit()  ##必须要commit

res = cur.fetchall() #获取所有返回的结果

print(res)

cur.close()  #关闭游标

coon.close()  #关闭数据库

定义数据库函数

 def my_db(host,user,passwd,db,sql,port=3306,charset='utf-8'):

     import pymysql

     coon =pymysql.connect(

         user=user,passwd=passwd,host=host,port=port,

         db=db,charset=charset

     )

     cur = coon.cursor()

     cur.execute(sql)

     if sql.strip()[:6].upper()=='SELECT':

         res = cur.fetchall()

     else:

         coon.commit()

         res = 'OK'

     cur.close()

     coon.close()

     return res

Tips:

1. 可以这样定义变量:一次性的定义多个变量

2. 操作数据库执行sql时,如果查询条件是字符串,先用占位符%s占位,然后在后面写上字符串,如下所示:

res = my_db('select password from liujing where username = "%s" and password = "%s";'%(username_login,m_pwd_login))

3. 指定sql返回结果是字典类型:建立游标的时候,可以指定游标类型返回的就是一个字典。mydb返回的是一个list,list内容是字典。

cur = coon.cursor(cursor=pymysql.cursors.DicCursor)

4. fetchall()  #获取到这个sql执行的全部结果,它把数据库表里面的每一行数据放到一个list里面

fetchone() #  获取到这个sql执行的一条结果,它返回的就只有一条数据

如果sql语句执行的结果是多条数据的时候,那就用fetchall()

如果你能确定sql执行的结果是一条数据的时候,那就用fetchone()

5. 要动态获取到标的字段 cur.descrption能获取到表结构,进而获取表的字段

fileds = [filed[0] for filed in cur.description]

6.enumerate([list,list2])  #循环的时候,能够直接获取到下标和该下标所代表的值

fileds = ['id','name','sex','addr','gold','score']

for index,filed in enumerate(fileds):

print(index,filed)    #index在循环的时候会自动加一

  

二、操作excel

写excel

 import xlwt

 book = xlwt.Workbook() #新建一个excel

 sheet = book.add_sheet('sheet1') # 加sheet页

 sheet.write(0,0,'姓名')  #第一行,第一列,写入的内容

 sheet.write(0,1,'年龄')  #第一行,第二列,写入的内容

 sheet.write(0,2,'性别')  #第一行,第三列,写入的内容

 book.save('stu.xls')  #结尾一定要用xls

读excel

 import xlrd
book = xlrd.open_workbook('app_student.xls') #打开excel
sheet = book.sheet_by_index(0) #根据sheet页的顺序选择sheet页
sheet2 = book.sheet_by_name('sheet1') #根据sheet页名称选择sheet页
print(sheet.cell(0,0).value) #获取sheet页里面第一行第一列的值
print(sheet.cell(1,0).value) #获取sheet页里面第二行第一列的值
print(sheet.row_values(0)) #获取第一行一整行的内容,放到了list里面
print(sheet.row_values(1)) #获取第二行一整行的内容,放到了list里面
print(sheet.nrows) #获取excel中共有多少行
for i in range(sheet.nrows): ##循环获取到每行的数据
print(sheet.row_values(i)) ##打印每一行的数据
print(sheet.ncols) #获取excel里面总共有多少列
print(sheet.col_values(0))#获取一整列的内容,放到了list里面
for i in range(sheet.ncols):##循环获取到每列的数据
print(sheet.col_values(i)) #打印每一列的数据

修改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(0) #通过sheet页的先后获取某sheet页 ##将app_student.xls的字段名称改为lis = ['编号','名字','性别','年龄','地址','班级','手机号','金币']里面的字段名称
# sheet.write(0,0,'编号') #如果字段很多的话,这样写需要很多行代码
# sheet.write(0,1,'名字')
lis = ['编号','名字','性别','年龄','地址','班级','手机号','金币']
# col=0
# for l in lis:
# sheet.write(0,col,l)
# col+=1
for col,filed in enumerate(lis):
sheet.write(0,col,filed)
new_book.save('app_student.xls')

Python学习笔记_Mysql数据库、Excel的更多相关文章

  1. python学习笔记——mongodb数据库

    1 概述 1.1 文件管理阶段 优点:可以长期保存 能存储大量数据 缺点:没有结构化的组织 查找不方便 数据容易冗余 1.2 数据库管理阶段 有文件存储的优点,同时解决了文件存储的问题 缺点 : 操作 ...

  2. Python学习笔记020——数据库基本操作

    本数据库的操作是Linux虚拟机平台下进行的 1 启动和链接MySQL服务 1.1 服务端 (1)查看服务状态 sudo /etc/init.d/mysql stauts (2)启动服务端 sudo ...

  3. Python学习笔记020——数据库知识概述

    数据库概述 1 提供数据库的软件都有哪些 MySQL.SQL_Server.Oracle.DB2.Mariadb.MongoDB ... (1)是否开源 开源软件:MySQL.Mariadb.Mong ...

  4. Python学习笔记_读Excel去重

    读取一个Excel文件,按照某列关键字,如果有重复则去掉 这里不介绍所有的解决办法,只是列出一个办法. 软件环境: OS:Win10 64位 Python 3.7 测试路径:D:\Work\Pytho ...

  5. Python学习笔记_Python向Excel写入数据

    实验环境 1.OS:Win 10 64位 2.Python 3.7 3.如果没有安装xlwt库,则安装:pip install xlwt 下面是从网上找到的一段代码,网上这段代码,看首行注释行,是在L ...

  6. Python学习笔记_操作Excel

    Python 操作Exel,涉及下面几个库: 1.xlrd 读取Excel文件 2.xlwt 向Excel文件写入,并设置格式 3.xlutils 一组Excel高级操作工具,需要先安装xlrd和xl ...

  7. Python学习笔记 使用数据库SQlite Mysql

    SQLite是一种嵌入式数据库,它的数据库就是一个文件.由于SQLite本身是C写的,而且体积很小,所以,经常被集成到各种应用当中, 甚至在IOS和Android的APP中都可以集成 Python就内 ...

  8. 10 python学习笔记-操作数据库(十)

    在功能.接口测试中,常常需要通过数据库的操作,来准备数据.检测环境及核对功能.接口的数据库操作是否正确. 在自动化测试中,就需要我们用代码连接数据库自动完成数据准备. 环境检查及数据库断言的功能.数据 ...

  9. Python学习笔记:读取Excel的xlrd模块

    一.安装xlrd 可以使用命令行安装也可使用pycharm进行安装 表示xlrd库已经安装成功,安装成功后,我们就可以导入使用了. 二.xlrd说明 (1.单元格常用的数据类型包括 0:empty(空 ...

随机推荐

  1. *LOJ#2322. 「清华集训 2017」Hello world!

    $n \leq 50000$的树,有点权$\leq 1e13$,$q \leq 400000$次操作,有两种操作:从$s$跳到$t$每次$k$步,不到$k$步直接跳到$t$,每次把经过的点取根号:同样 ...

  2. MySql将查询结果插入到另外一张表

    今天遇到一个业务需求是这样的:对在职员工超过55岁提醒.我想的思路是查询员工表,然后将超过55岁的人的信息存到另一个表,并且以消息的形式给用户提示,用户处理掉之后此消息失效(在数据库做标记). 不管是 ...

  3. hdu 1717

    小数化分数2 Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Sub ...

  4. Linux系统下rz/sz工具的安装

    (1)编译安装 root 账号登陆后,依次执行以下命令: wget http://www.ohse.de/uwe/releases/lrzsz-0.12.20.tar.gz tar zxvf lrzs ...

  5. R读数据stringsAsFactors=F,存数据时row.names = F

    stringsAsFactors=F   以前在r里读数据,经常把character读成factor,还得费半天劲把它转回来,尤其是把factor转成numeric还没有那么直接.例如: dat< ...

  6. 感受lambda之美,推荐收藏,需要时查阅

    一.引言二.java重要的函数式接口1.什么是函数式接口1.1 java8自带的常用函数式接口.1.2 惰性求值与及早求值2.常用的流2.1 collect(Collectors.toList())2 ...

  7. IntelliJ IDEA配置Tomcat/Jetty运行Web项目

    一.使用Maven的POM引入插件的形式: 这种方式只需在POM中引入Tomcat/Jetty的插件即可运行.参考:http://www.cnblogs.com/EasonJim/p/6687272. ...

  8. 【Linux】在虚拟机上安装ubuntu

    虚拟机安装步骤  参考:http://www.cnblogs.com/sxdcgaq8080/p/7466529.html 在安装ubuntu系统之前,当然是下载一个ubuntu的iso镜像在本地啦. ...

  9. setState 是异步的

    1.解决 setState 异步问题 // 查询 handleSearch(e){ // 禁止默认行为 e.preventDefault(); // 获取 form 表单的值 this.setStat ...

  10. 《python源代码剖析》笔记 Python的编译结果

    本文为senlie原创.转载请保留此地址:http://blog.csdn.net/zhengsenlie 1.python的运行过程 1)对python源码进行编译.产生字节码 2)将编译结果交给p ...