各位用户为了找寻关于Python Socket传输文件示例的资料费劲了很多周折。这里教程网为您整理了关于Python Socket传输文件示例的相关资料,仅供查阅,以下为您介绍关于Python Socket传输文件示例的详细内容

发送端可以不停的发送新文件,接收端可以不停的接收新文件。

例如:发送端输入:e:visio.rar,接收端会默认保存为 e:new_visio.rar,支持多并发,具体实现如下;

接收端:

方法一:

? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 #-*- coding: UTF-8 -*- import socket,time,SocketServer,struct,os,thread host='192.168.50.74' port=12307 s=socket.socket(socket.AF_INET,socket.SOCK_STREAM) #定义socket类型 s.bind((host,port)) #绑定需要监听的Ip和端口号,tuple格式 s.listen(1)     def conn_thread(connection,address):   while True:     try:       connection.settimeout(600)       fileinfo_size=struct.calcsize('128sl')       buf = connection.recv(fileinfo_size)       if buf: #如果不加这个if,第一个文件传输完成后会自动走到下一句         filename,filesize =struct.unpack('128sl',buf)         filename_f = filename.strip('0')         filenewname = os.path.join('e:',('new_'+ filename_f))         print 'file new name is %s, filesize is %s' %(filenewname,filesize)         recvd_size = 0 #定义接收了的文件大小         file = open(filenewname,'wb')         print 'stat receiving...'         while not recvd_size == filesize:           if filesize - recvd_size > 1024:             rdata = connection.recv(1024)             recvd_size += len(rdata)           else:             rdata = connection.recv(filesize - recvd_size)             recvd_size = filesize           file.write(rdata)         file.close()         print 'receive done'         #connection.close()     except socket.timeout:       connection.close()     while True:   connection,address=s.accept()   print('Connected by ',address)   #thread = threading.Thread(target=conn_thread,args=(connection,address)) #使用threading也可以   #thread.start()   thread.start_new_thread(conn_thread,(connection,address))   s.close()

方法二:

? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 #-*- coding: UTF-8 -*- import socket,time,SocketServer,struct,os host='192.168.50.74' port=12307 ADDR=(host,port)   class MyRequestHandler(SocketServer.BaseRequestHandler):    def handle(self):       print('connected from:', self.client_address)     while True:       fileinfo_size=struct.calcsize('128sl') #定义文件信息。128s表示文件名为128bytes长,l表示一个int或log文件类型,在此为文件大小       self.buf = self.request.recv(fileinfo_size)       if self.buf: #如果不加这个if,第一个文件传输完成后会自动走到下一句         self.filename,self.filesize =struct.unpack('128sl',self.buf) #根据128sl解包文件信息,与client端的打包规则相同         print 'filesize is: ',self.filesize,'filename size is: ',len(self.filename) #文件名长度为128,大于文件名实际长度         self.filenewname = os.path.join('e:',('new_'+ self.filename).strip('00')) #使用strip()删除打包时附加的多余空字符         print self.filenewname,type(self.filenewname)         recvd_size = 0 #定义接收了的文件大小         file = open(self.filenewname,'wb')         print 'stat receiving...'         while not recvd_size == self.filesize:           if self.filesize - recvd_size > 1024:             rdata = self.request.recv(1024)             recvd_size += len(rdata)           else:             rdata = self.request.recv(self.filesize - recvd_size)             recvd_size = self.filesize           file.write(rdata)         file.close()         print 'receive done'     #self.request.close()   tcpServ = SocketServer.ThreadingTCPServer(ADDR, MyRequestHandler) print('waiting for connection...' ) tcpServ.serve_forever()

发送端:

? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 #-*- coding: UTF-8 -*- import socket,os,struct s = socket.socket(socket.AF_INET,socket.SOCK_STREAM) s.connect(('192.168.50.74',12307)) while True:      filepath = raw_input('Please Enter chars:rn')   if os.path.isfile(filepath):     fileinfo_size=struct.calcsize('128sl') #定义打包规则     #定义文件头信息,包含文件名和文件大小     fhead = struct.pack('128sl',os.path.basename(filepath),os.stat(filepath).st_size)     s.send(fhead)     print 'client filepath: ',filepath     # with open(filepath,'rb') as fo: 这样发送文件有问题,发送完成后还会发一些东西过去     fo = open(filepath,'rb')     while True:       filedata = fo.read(1024)       if not filedata:         break       s.send(filedata)     fo.close()     print 'send over...'     #s.close()

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。

原文链接:http://www.cnblogs.com/dreamer-fish/p/5501924.html