【Python】python读取文件操作mysql
尾大不掉,前阵子做检索测试时,总是因为需要业务端操作db和一些其他服务,这就使得检索测试对环境和数据依赖性特别高,极大提高了测试成本。
Mock服务和mysql可以很好的解决这个问题,所以那阵子做了两个工作:
1 使用公司的service框架Mock服务;
2 使用python语言Mock mysql数据。
部分1只需要了解公司框架即可进行编写,本文主要记录下python操作mysql的部分。
一 安装环境
安装python即需要的MySQLdb模块(yum install MySQL-python.x86_64),如下,安装成功。
[root@bjdhj-- ~]# python
Python 2.6. (r266:, Feb , ::)
[GCC 4.4. (Red Hat 4.4.-)] on linux2
Type "help", "copyright", "credits" or "license" for more information.
>>> import MySQLdb
>>>
二 实现python操作数据库
1 我第一次实现的是读取文件操作数据库(注释掉的为自增键处理)如下:
#-*- coding:utf- -*-
import MySQLdb
from itertools import islice
try:
conn = MySQLdb.connect(host='localhost',user='root',passwd='',port=,charset='utf8')#连接mysqldb
cur = conn.cursor()
conn.select_db('test')
# cur.execute('select max(id) from student')#获取mysql中该表的自增键最大值,向后添加。
# maxid = cur.fetchall()[]
# print 'maxid%id'%maxid
# start = count+
f = file('data2.txt')
list = []
line_num =
for line in islice(f,,None):#读取txt文件,跳过标题行
strs = line.split(",") #文件各字段逗号分隔
line_num = line_num+
print len(strs)
if len(strs)!=: #缺少字段时,跳过该行
print '%d 行缺少字段,请检查文件'%line_num
continue
data = (strs[],strs[],strs[],strs[],strs[],strs[],strs[],strs[],strs[],strs[],strs[],strs[],strs[],strs[],strs[],strs[],strs[],strs[],strs[],strs[],strs[],strs[],strs[],strs[],strs[].replace("\n","")) #对strs[24]空格进行处理
print data
# start = start+
list.append(data) #将data记录到list中,对list执行插入操作
f.close
cur.executemany('insert into creative_info_test values(%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s)',list)
conn.commit() #提交
cur.close()
conn.close()
print 'OK'
except MySQLdb.Error,e:
print "MySQL Error %d:%s"%(e.args[],e.args[])
2 领导说每条记录字段太多了(多表多字段),让我固定到脚本里,再单独更改,于是对第一版进行了修改,使用了字典dict:
#-*- coding:utf- -*-
import MySQLdb
conn = MySQLdb.connect(host='localhost',user='root',passwd='',port=,charset='utf8')#连接mysqldb
cur = conn.cursor()
conn.select_db('test')
#逻辑:一次操作只为一次测试使用,所以第一步清除记录;第二步根据条数插入数据;第三个对插入数据进行个性化设置(部分字段的更新)。
try:
Delete()#数据清除
Producer()#将默认数据插入mysql,注意自增主键
Update()#个性化数据更新
conn.commit()#提交
cur.close()
conn.close()
except MySQLdb.Error,e:
print 'MySQL Error %d,%s'%(e.args[0],e.args[1])
#具体实现:插入数据,由于多表插入,切表与表之间有相同字段,所以根据条数做统一设置。
def Producer():
print 'input numbers :'
num = input()#请多写一条
for i in range(,num):
table1['user_id']=i
table2['user_id']=i...
#insert table1
user_info = [user['user_id']...]
cur.execute('insert into user_test values(%s,...)',table1)
#insert table2
...以下类似处理 def Update():
print 'input your sql语句 file name:'
filename = raw_input()
f=file(filename)
for line in f.readlines():
operator your sql update #写update语句即可
def Delete():
cur.execute('delete from table1')
cur.execute('delete from table2')
...
#每个表对应一个dict,其字段为字典元素,为各字段设置默认值
table1={
'user_id':'',
'user_name':
...,
}
table2={
...
}
三 附excel文件的读取,嗯,顺便感慨,python真棒:
import csv
f = open('creative_info_test.csv','rb')
reader = csv.reader(f)
for row in reader:
print row
f.close
【Python】python读取文件操作mysql的更多相关文章
- Python入门篇-文件操作
Python入门篇-文件操作 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.文件IO常用操作 open:打开 read:读取 write:写入 close:关闭 readlin ...
- python 历险记(三)— python 的常用文件操作
目录 前言 文件 什么是文件? 如何在 python 中打开文件? python 文件对象有哪些属性? 如何读文件? read() readline() 如何写文件? 如何操作文件和目录? 强大的 o ...
- Python的高级文件操作(shutil模块)
Python的高级文件操作(shutil模块) 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 如果让我们用python的文件处理来进行文件拷贝,想必很多小伙伴的思路是:使用打开2个 ...
- python基础篇(文件操作)
Python基础篇(文件操作) 一.初始文件操作 使用python来读写文件是非常简单的操作. 我们使用open()函数来打开一个文件, 获取到文件句柄. 然后通过文件句柄就可以进行各种各样的操作了. ...
- python os&shutil 文件操作
python os&shutil 文件操作 # os 模块 os.sep 可以取代操作系统特定的路径分隔符.windows下为 '\\' os.name 字符串指示你正在使用的平台.比如对于W ...
- python在读取文件时出现 'gbk' codec can't decode byte 0x89 in position 68: illegal multibyte sequence
python在读取文件时出现“UnicodeDecodeError:'gbk' codec can't decode byte 0x89 in position 68: illegal multiby ...
- Python之常用文件操作
Python之常用文件操作
- python 从csv文件插入mysql数据库
一个工作遇到的问题,将excel文件的内容插入到mysql数据库中. 总体思路是 excel文件-->转换成csv文件-->csv文件读取-->读取数据插入mysql数据库 用到py ...
- Python开发【第三篇】:Python基本之文件操作
Python基本之文本操作 一.初识文本的基本操作 在python中打开文件有两种方式,即:open(...) 和 file(...) ,本质上前者在内部会调用后者来进行文件操作,推荐使用 open ...
随机推荐
- Xamarin for Visual Studio 3.11.658 Alpha 版 破解补丁
注意:此版本为 Alpha 版,版本迭代较频繁,仅供尝鲜 前提概要 全新安装请参考 安装 Xamarin for Visual Studio. 最新稳定版请参考 Xamarin for Visual ...
- 解决Unable to load R3 module ...VBoxDD.dll (VBoxDD):GetLastError=1790
解决Unable to load R3 module ...VBoxDD.dll (VBoxDD):GetLastError=1790 参考文章:http://blog.sina.com.cn/s/b ...
- java实现大数加法、乘法(BigDecimal)
之前写过用vector.string实现大数加法,现在用java的BigDecimal类,代码简单很多.但是在online-judge上,java的代码运行时间和内存大得多. java大数加法:求a+ ...
- spring 与 CXF 整合 webservice 出现error “Unable to locate Spring NamespaceHandler for XML schema namespace” 总结
我试了多个版本的spring 发现 出现error : Unable to locate Spring NamespaceHandler for XML schema namespace 并非都是sp ...
- MVC下基于DotNetOpenAuth 实现SSO单点登录
具体官网可以查看:http://dotnetopenauth.net/,托管地址:https://github.com/DotNetOpenAuth/DotNetOpenAuth 可能需要FQ 博客园 ...
- [cocoapods]cocoapods问题解决
错误1. While executing gem no such name 错误原因:gem 网址被挡住了. 解决办法:设置https://ruby.taobao.org/ 详情参考 http://w ...
- 37. Sudoku Solver
题目: Write a program to solve a Sudoku puzzle by filling the empty cells. Empty cells are indicated b ...
- AndroidRichText 让Textview轻松的支持富文本(图像ImageSpan、点击效果等等类似QQ微信聊天)
代码地址:https://github.com/Luction/AndroidRichText AndroidRichText帮助实现像QQ,微信一样的,一个TextView里既有文字又有表情又有图片 ...
- Android 线程通讯类Handler
handler是线程通讯工具类.用于传递消息.它有两个队列: 1.消息队列 2.线程队列 消息队列使用sendMessage和HandleMessage的组合来发送和处理消息. 线程队列类似一段代码, ...
- NYOJ-253 凸包
LK的旅行 时间限制:2000 ms | 内存限制:65535 KB 难度:5 描述 LK最近要去某几个地方旅行,她从地图上计划了几个点,并且用笔点了出来,准备在五一假期去这几个城市旅行.现在 ...