【初学python】使用python连接mysql数据查询结果并显示

因为测试工作经常需要与后台数据库进行数据比较和统计,所以采用python编写连接数据库脚本方便测试,提高工作效率,脚本如下(python连接mysql需要引入第三方库MySQLdb,百度下载安装)

#-*- coding: utf-8 -*-

import MySQLdb, datetime, time
#code数字含义
code_mean = {10:"开始下载(10)",
				   11:"下载完成(11)",
				   12:"安装界面(12)",
				   13:"安装成功(13)",
				   14:"启动游戏(14)",
				   16:"更新开始(16)"}
#Networktype数字含义
network_type_mean = {1:"3G  网络",
				     2:"2G  网络",
					 3:"WIFI网络"}
#当前测试人员拥有手机
phonelist = {1:"0049990********", 2:"8689430********", 3:"3558680********"}
#当前系统时间
nowtime = (datetime.datetime.fromtimestamp(time.time()).strftime('%Y-%m-%d %H:%M:%S'))
print "当前时间:" + nowtime
today = str(nowtime).split()[0]
#去除日期
HMS = nowtime.split()[1]

print "目前测试人员拥有的手机如下:"
print "HTC    ***  :1"
print "HTC    ****  :2"
print "HUAWEI ***** :3"

phont_imei = raw_input("请选择你要查询的手机,输入上列手机对应的数字即可:")
time_start = raw_input("请输入需要查询的起始时间(格式如后:" + HMS + ",默认日期为今天): ")
imei = phonelist[int(phont_imei)]
#查询开始时间
starttime = datetime.datetime.now()

print "开始连接数据库......"
try:
	db = MySQLdb.connect(host="***.***.***.***", port=****, user="****", passwd="****", db="****")
	cursor = db.cursor()
	print "数据库连接成功,开始进行查询......"
	cursor.execute('''SELECT
	****,
	****,
	****,
	****,
	****
	from ****
	WHERE
	**** =  \'''' + imei + '''\' AND
	**** > \'''' + today + " " + time_start + '''' AND
	**** IN (10, 11, 12,13,14,16)
	ORDER BY
	**** DESC
	''')
	result = cursor.fetchall()
	print "已获取查询结果,开始断开数据库连接....."
	cursor.close()
	db.close()
except MySQLdb.Error,e:
     print "Mysql Error %d: %s" % (e.args[0], e.args[1])
else:
	print "断开数据库连接成功,开始展示查询结果......"
	if bool(result) != True:
		print "( ⊙ o ⊙ )啊哦,竟然没有查询到数据结果,请检查下查询时间"
	else:
		#对查询出的数据进行处理,方便查看
		print ""
		print "++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++"
		i = 0
		for record in result:
			sqldata = result[i]
			time = sqldata[0]
			code = sqldata[1]
			name = sqldata[2]
			networktype = sqldata[4]
			print network_type_mean[int(networktype)] + \
					" " + str(time).split()[1] + \
					" " + code_mean[int(code)] + \
					" " + name
			i += 1
		print "++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++"
#结果展示时间
endtime = datetime.datetime.now()
wast_time = (endtime - starttime).seconds
print "本次查询总共耗时:" + str(wast_time) + " 秒 " + "查询手机IMEI:" +  phonelist[int(phont_imei)]

  目前脚本的缺点是只能进行一次性查询,之后再进行优化使之能进行多次查询后再断开数据库连接

原文地址:https://www.cnblogs.com/levelksk/p/3401325.html