python -SFTP


#coding=utf-8
'''
Created on Jun 6, 2017

@author: wb
'''
import wx
import os
import shutil
import sys
import os.path
import paramiko
from paramiko import sftp
import time
import WtgGetCfg
from WtgGetCfg import getCfg
from WtgGetCfg import saveCfg

def main():
    global path
    global rootdir  # 指明被遍历的文件夹
    global ToPath
    global host
    global user
    global passwd
    global mtime
#      time.strftime('%Y_%m',time.localtime(time.time()))
    txtName = time.strftime('%Y_%m',time.localtime(time.time()))
    f = file(txtName, "a+")
#    history = f.read()
    f.close()
   
    print txtName
   
    host,rootdir,user,passwd,lastTime,ToPath = getCfg()
   
    if not os.path.isdir(ToPath):
        os.makedirs(ToPath)
        print 'New Floder Successful'

    mtime = lastTime
    historyTime = time.strptime(lastTime,"%a %b %d %H:%M:%S %Y")

    print time.mktime(historyTime)

    print host,rootdir,user,passwd,lastTime,ToPath

    try:
        t = paramiko.Transport((host,22))
        t.connect(username=user, password=passwd)
        sftp = paramiko.SFTPClient.from_transport(t)
    except:
        print "connection failed "
        f2 = open(txtName, "a")
        name = "connection failed"+"\t"+time.strftime('%Y-%m-%d %H:%M:%S',time.localtime(time.time()))+"\n"
        f2.write(name)
        f2.close()
#        app = wx.PySimpleApp()
        app = wx.App()
        dlg = wx.MessageDialog(None, 'connection failed'+"\n"+time.strftime('%Y-%m-%d %H:%M:%S',time.localtime(time.time())),
                              'Warning !',
                              wx.OK | wx.ICON_INFORMATION
                              #wx.YES_NO | wx.NO_DEFAULT | wx.CANCEL | wx.ICON_INFORMATION
                              )
        dlg.ShowModal()
        dlg.Destroy()
        return -1   

   
    for parent,dirnames,filenames in os.walk(u''+rootdir.encode('gbk')):    #三个参数:分别返回1.父目录 2.所有文件夹名字(不含路径) 3.所有文件名字
        f1 = open(txtName, "a")
        for filename in filenames:                        #输出文件信息
#        print "parent is:" + parent
#        print "filename is:" + filename
#        print "the full name of the file is:" + os.path.join(parent,filename) #输出文件路径信息
            mtime = time.ctime(os.path.getmtime(os.path.join(parent,filename)))
            print mtime
       
            nowTime = time.strptime(mtime,"%a %b %d %H:%M:%S %Y")
            print time.mktime(nowTime)
            if nowTime > historyTime :
                print filename
               
                if sftp.put(os.path.join(parent,filename),filename):
                   
                    shutil.copy (os.path.join(parent,filename), ToPath)
                    os.remove (os.path.join(parent,filename))
                    print 'success'
                    name = filename +"\t"+"ok"+"\t"+time.strftime('%Y-%m-%d %H:%M:%S',time.localtime(time.time()))+"\n"
                    f1.write(name)
                else:
                    app = wx.App()
                    dlg = wx.MessageDialog(None, filename+'upload failed',
                              'Warning !',
                              wx.OK | wx.ICON_INFORMATION
                              #wx.YES_NO | wx.NO_DEFAULT | wx.CANCEL | wx.ICON_INFORMATION
                              )
                    dlg.ShowModal()
                    dlg.Destroy()
                   
                    print 'be defeated'
                    print filename
                    name = filename +"\t"+"fail"+"\t"+time.strftime('%Y-%m-%d %H:%M:%S',time.localtime(time.time()))+"\n"
                    f1.write(name)
           
                       
     
#        if filename in history:
           
            else:
                print '已经上传过'
#         
    saveCfg(mtime)
    f1.close()
if __name__ == '__main__':
    main()
         

先上代码,以上是SFTP上传的 Python代码。

这个段代码配有一个XML文件的配置文件(必须和运行程序在同一目录下)

文件名uploader.xml

<data>
  <app>
  <IP>192.168.1.100</IP>
  <path>C:/Users/Desktop/new</path>
  <user>test</user>
  <password>11</password><lastTime>Mon Dec 05 17:59:32 2016</lastTime>
  <ToPath>C:/Desktop/opc/new2</ToPath></app>
</data>

有配置文件必须要配带有 操作文件的 代码:

#!/usr/bin/python
#coding=utf-8 
from xml.dom.minidom import parse
import xml.dom.minidom
import os

global xmlFile
xmlFile = "\\uploader.xml"

global folder
global IP_Addr
global total_cycle


def getCfg():
    global appDir
    global xmlFile
    appDir = os.getcwd()
    xmlFile = appDir + xmlFile
    if  (os.path.exists(xmlFile))  :
        DOMTree = xml.dom.minidom.parse(xmlFile)
        Data = DOMTree.documentElement
        Apps = Data.getElementsByTagName("app")
        for app in Apps: 
            if app.hasAttribute("folder"):
                print "foldername: %s" % app.getAttribute("folder")     
#       
            ip = app.getElementsByTagName('IP')[0]
            #print "total_wtg: %s" % total_wtg.childNodes[0].data         
           
            user = app.getElementsByTagName('user')[0]
           
            password = app.getElementsByTagName('password')[0]
           
            lastTime = app.getElementsByTagName('lastTime')[0]
            #print "server_option: %s" % server_option.childNodes[0].data       
           
            path = app.getElementsByTagName('path')[0]
#            print "wf_name: %s" % wf_name.childNodes[0].data

            ToPath = app.getElementsByTagName('ToPath')[0]
           
   
        return  ip.childNodes[0].data,  \
        path.childNodes[0].data,user.childNodes[0].data,password.childNodes[0].data,lastTime.childNodes[0].data,\
        ToPath.childNodes[0].data
     

def saveCfg(time):
    global xmlFile
    DOMTree = xml.dom.minidom.parse(xmlFile)
    Data = DOMTree.documentElement
    Apps = Data.getElementsByTagName("app")
    for app in Apps: 
        if app.hasAttribute("folder"):
            print "foldername: %s" % app.getAttribute("folder")
     
        lastTime= app.getElementsByTagName('lastTime')[0]
        print "folder: %s" % lastTime.childNodes[0].data
        # folder
        lastTime.childNodes[0].data = time
       
       
        f = file(xmlFile, "w")
        Data.writexml(f)
        f.close()       
    return True
   

这样的话就可以实现相对比较灵活点的  SFTP 上传。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 211,884评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,347评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,435评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,509评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,611评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,837评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,987评论 3 408
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,730评论 0 267
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,194评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,525评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,664评论 1 340
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,334评论 4 330
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,944评论 3 313
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,764评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,997评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,389评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,554评论 2 349

推荐阅读更多精彩内容