尾大不掉,前阵子做检索测试时,总是因为需要业务端操作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. linux的strace命令用法

    strace命令用法 调用:strace [ -dffhiqrtttTvxx ] [ -acolumn ] [ -eexpr ] …[ -ofile ] [ -ppid ] … [ -sstrsize ...

  2. 【转】 wget 命令用法详解

    wget是在Linux下开发的开放源代码的软件,作者是Hrvoje Niksic,后来被移植到包括Windows在内的各个平台上.它有以下功能和特点:(1)支持断点下传功能:这一点,也是网络蚂蚁和Fl ...

  3. Project Euler 99:Largest exponential 最大的幂

    Largest exponential Comparing two numbers written in index form like 211 and 37 is not difficult, as ...

  4. iOS使用Charts框架绘制—柱形图

    首先看一下最终要实现的效果: 最终效果 一.初始化barChartView 绘制柱形图需要用到BarChartView这个类,下面是初始化代码: self.barChartView = [[BarCh ...

  5. C++:虚函数的详解

    5.4.2 虚函数详解 1.虚函数的定义 虚函数就是在基类中被关键字virtual说明,并在派生类重新定义的函数.虚函数的作用是允许在派生类中重新定义与基类同名的函数,并且可以通过基类指针或引用来访问 ...

  6. Splunk常用命令

    重启/查看状态/停止splunk [root@localhost splunk]# /opt/splunk/bin/splunk restart / status / stop

  7. 离线应用Application Cache详解

    特点:     1.离线可访问            - 没有网络仍可访问整个应用     2.很小的服务器负载  - 缓存在本地,不需要到服务器请求     3.高速                 ...

  8. ubuntu 映射网络驱动器到本地

    公司办公都是在ubuntu服务器上,所以每每拷贝修改文件都要ftp之类的,实在不方便. 索性将服务器挂载到自己本地目录下. 服务器端参考其他samba安装和配置.这里只是说下本地自动挂载方法. 一.首 ...

  9. Linux /bin、/sbin、/usr/bin、/usr/sbin目录的区别

    在linux下我们经常用到的四个应用程序的目录是/bin./sbin./usr/bin./usr/sbin .而四者存放的文件一般如下:     bin目录:  bin为binary的简写主要放置一些 ...

  10. java导出excel报表

    1.java导出excel报表: package cn.jcenterhome.util; import java.io.OutputStream;import java.util.List;impo ...