python 导出mysql 视图_python实现处理mysql结果输出方式

在运维过程中,经常需要读取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结果输出方式就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值