明霞山资源网 Design By www.htccd.com
在运维过程中,经常需要读取mysql的结果输出并进行响应的处理,这节介绍如何用Python读取mysql结果表并进行相应的整理。
进行mysql结果文件输出:
mysql -h10.20.10.207 -uroot -ppasswd test -e "select sendorderid, (price*100),mob from interfacelog where merid='****' >/home/anan/interfacelog.txt ##这里写你需要执行的sql语句将结果打印成一个文件
/home/anan/interfacelog.txt内容如下,因为保密性要求,只显示一条数据
程序介绍: readInterfacelog
实现读取mysql的打印的结果并执行相应的语句。这里我们以重新输出结果作为演示。
具体实现
#!/usr/bin/env python # -*- coding: utf-8 -*- # @Date : 2018-07-19 11:39:00 # @Author : Zhou Jiaan # @Version : V1.0 import os import sys import time import re def readInterfacelog(merid): with open('/home/anan/interfacelog.txt', 'r') as f: #读取mysql输出文件 lines = f.readlines() for line in lines[2::1]: #因为第一第二行并不是我们需要处理的数据而是无效数据故我们忽略前两行直接读取后续我们需要的内容 interfacelog = re.split(r'[\t|\s]\s*', line) #对文件进行切分, sendorderid = interfacelog[0] price100 = interfacelog[1] mob = interfacelog[2] print(sendorderid, price100, mob) ###这里进行你需要对输出进行的操作。 # os.system('/usr/local/bin/MsgSrvClient -h *.*.*.* -p 6004 -w0 -e "IFTran SlowInt 1 %s %s %s NA 1 5000 120 NA 22 NA NA %s NA NA NA";'%(sendorderid,price100,merid,mob)) ##这是我的需求 time.sleep(0.1) def main(): # merid=sys.argv[1] try: merid_num = sys.argv[1] except Exception as e: merid_num = input("请输入merid:") else: print("输出merid_num:{}".format(merid_num)) finally: merid = merid_num print(merid) readInterfacelog(merid) if __name__ == '__main__': main()
补充知识:python打印mysql版本信息
#第一句话写成#!/usr/local/python不行,还不知道为啥
#!/usr/bin/env python import MySQLdb db = MySQLdb.connect("192.168.74.130","root","l","") cursor=db.cursor() cursor.execute("select version()") data=cursor.fetchone() print "Database version : %s " % data db.close()
以上这篇python实现处理mysql结果输出方式就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
明霞山资源网 Design By www.htccd.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
明霞山资源网 Design By www.htccd.com
暂无评论...
P70系列延期,华为新旗舰将在下月发布
3月20日消息,近期博主@数码闲聊站 透露,原定三月份发布的华为新旗舰P70系列延期发布,预计4月份上市。
而博主@定焦数码 爆料,华为的P70系列在定位上已经超过了Mate60,成为了重要的旗舰系列之一。它肩负着重返影像领域顶尖的使命。那么这次P70会带来哪些令人惊艳的创新呢?
根据目前爆料的消息来看,华为P70系列将推出三个版本,其中P70和P70 Pro采用了三角形的摄像头模组设计,而P70 Art则采用了与上一代P60 Art相似的不规则形状设计。这样的外观是否好看见仁见智,但辨识度绝对拉满。