尾大不掉,前阵子做检索测试时,总是因为需要业务端操作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的更多相关文章

  1. Python入门篇-文件操作

    Python入门篇-文件操作 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.文件IO常用操作 open:打开 read:读取 write:写入 close:关闭 readlin ...

  2. python 历险记(三)— python 的常用文件操作

    目录 前言 文件 什么是文件? 如何在 python 中打开文件? python 文件对象有哪些属性? 如何读文件? read() readline() 如何写文件? 如何操作文件和目录? 强大的 o ...

  3. Python的高级文件操作(shutil模块)

    Python的高级文件操作(shutil模块) 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 如果让我们用python的文件处理来进行文件拷贝,想必很多小伙伴的思路是:使用打开2个 ...

  4. python基础篇(文件操作)

    Python基础篇(文件操作) 一.初始文件操作 使用python来读写文件是非常简单的操作. 我们使用open()函数来打开一个文件, 获取到文件句柄. 然后通过文件句柄就可以进行各种各样的操作了. ...

  5. python os&shutil 文件操作

    python os&shutil 文件操作 # os 模块 os.sep 可以取代操作系统特定的路径分隔符.windows下为 '\\' os.name 字符串指示你正在使用的平台.比如对于W ...

  6. 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 ...

  7. Python之常用文件操作

    Python之常用文件操作

  8. python 从csv文件插入mysql数据库

    一个工作遇到的问题,将excel文件的内容插入到mysql数据库中. 总体思路是 excel文件-->转换成csv文件-->csv文件读取-->读取数据插入mysql数据库 用到py ...

  9. Python开发【第三篇】:Python基本之文件操作

    Python基本之文本操作 一.初识文本的基本操作 在python中打开文件有两种方式,即:open(...) 和  file(...) ,本质上前者在内部会调用后者来进行文件操作,推荐使用 open ...

随机推荐

  1. gcc / g++ 编译选项

    g++ -Wall -m64 -W -O2 a.cpp b.cpp -o a 用下面的命令编译,生成libtriangle.so  先生成动态库 g++ -g -fpic -shared -o lib ...

  2. MAC 上升级python为最新版本

    第1步:下载Python3.4 下载地址如下: 下载Mac OS X 64-bit/32-bit installer https://www.python.org/downloads/release/ ...

  3. lintcode 中等题:find the missing number 寻找缺失的数

    题目 寻找缺失的数 给出一个包含 0 .. N 中 N 个数的序列,找出0 .. N 中没有出现在序列中的那个数. 样例 N = 4 且序列为 [0, 1, 3] 时,缺失的数为2. 注意 可以改变序 ...

  4. unity3d泰斗破坏神2----课程列表

    免费 课时1:泰斗破坏神第一支预告视频 01:32免费 课时2:泰斗破坏神第二支预告视频 01:58第 1 章 : 游戏开始 用户登录 服务器选择课时3:游戏开始 用户登录 服务器选择课时4:素材介绍 ...

  5. PostMessage与SendMessage各自的问题

     深入解析SendMessage.PostMessage 本文将使用C++语言,在MFC框架的配合下给出PostMessage.SendMessage等的使用方式与使用不当造成的后果(讨论均针对自定义 ...

  6. 如何禁用 radio ,设置为只读,不能选定

    如何禁用 radio ,设置为只读,不能选定 禁用 radio ,设置为只读,不能选定: <input name="gender" type="radio" ...

  7. <<c 和指针 >> 部分笔记。

    最近竟然对指针有些迷惑了,分不清指针的指向.废话少说,复习.(下面内容来自<<c和指针>>) =指针 ==内存和地址 尽管一个字包含了4个字节,它仍然只有一个地址.至于是最左边 ...

  8. BZOJ 3132 上帝造题的七分钟(二维树状数组)

    题目链接:http://61.187.179.132/JudgeOnline/problem.php?id=3132 题意:给出一个矩阵,两种操作:(1)将某个子矩阵的数字统一加上某个值:(2)查询某 ...

  9. Android系统服务-WindowManager

      WindowManager是Android中一个重要的服务 (Service ).WindowManager Service 是全局的,是唯一的.它将用户的操作,翻译成为指令,发送给呈现在界面上的 ...

  10. 【笨嘴拙舌WINDOWS】伟大的变革

    "改革"."革命"."变革" 这几个词语毫无疑问是每一个时代必须被呼吁的词语,当一个国家没有人求变时,那是一个时代的悲剧.无论是文景之治,贞 ...