python是数据库语言吗_Python语言 数据库处理

本文主要向大家介绍了Python语言 数据库处理,通过具体的内容向大家展示,希望对大家学习Python语言有所帮助。

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

#!/bin/env python

'''

#Auth:karl

#Function: released version

#Date:2017/6/27

#Version:V1.0

'''

import sys,re,time,datetime

import paramiko

import logging

import ConfigParser

import traceback

import MySQLdb

import platform

import xlrd

reload(sys)

sys.setdefaultencoding('utf-8')

if "Linux" == platform.system():

Excelpath="/home/appdeploy/version/Version"

else:

Excelpath = "D:\\auto\\release\Version"

class Mysql_connect(object):

def __init__(self,*agre):

self.port=agre[0]

self.passwd=agre[1]

self.username=agre[2]

self.host=agre[3]

self.version=agre[4]

def File_get(self):

Excelfilepath="{path}_{version}/Filelist.xlsx".format(path=Excelpath,version=self.version)

workbook=xlrd.open_workbook(Excelfilepath)

booksheet = workbook.sheet_by_name('Sheet1')

self.p=list()

for row in range(booksheet.nrows):

row_data = []

for col in range(booksheet.ncols):

cel = booksheet.cell(row, col)

val = cel.value

try:

val = cel.value

val = re.sub(r'\s+', '', val)

except:

pass

if type(val) == float:

val = int(val)

else:

val = str(val)

row_data.append(val)

self.p.append(row_data)

self.__Mysql_deal()

def __Mysql_deal(self):

try:

con = MySQLdb.connect(user=self.username,passwd=self.passwd,db="version_release",port=int(self.port),charset="utf8")

dt = datetime.datetime.now().strftime("%Y-%m-%d %H:%M:%S")

cursor=con.cursor()

cursor.execute("CREATE TABLE IF NOT EXISTS version(Id INT PRIMARY KEY AUTO_INCREMENT,\

File VARCHAR (30) DEFAULT null,Release_date TIMESTAMP,Instruction text)")

sql="""INSERT INTO version (File,Release_date,Instruction) VALUES (%s, %s, %s) """

for value in self.p:

valuse=(value[0],dt,value[1])

result=cursor.execute(sql,valuse)

cursor.close()

con.commit()

con.close()

except MySQLdb.Error, e:

print "Error %d: %s" % (e.args[0], e.args[1])

sys.exit(1)

def File_deal(self):

try:

ssh = paramiko.SSHClient()

ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())

ssh.connect(self.host,22, "root","****", timeout=5)

for name in self.p:

route_0=name[0]

route=name[1]

cmd="\cp -vr {path}_{version}/{filename}.xls {dir_new}".format(path=Excelpath,version=self.version,filename=route_0,dir_new=route)

stdin, stdout, stderr = ssh.exec_command(cmd)

for out_msg in stdout.readlines():

print out_msg

except Exception, e:

print '%s\tError\n' % (self.host) ,e

ssh.close()

def main():

agre = ["3306", "*****", "root","xx.xx.xx.xx","3.0"]

stg = Mysql_connect(*agre)

stg.File_get()

stg.File_deal()

if __name__ == '__main__':

try:

main()

except Exception as e:

print traceback.format_exc()

本文由职坐标整理并发布,希望对同学们学习Python有所帮助,更多内容请关注职坐标编程语言Python频道!

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值