时间:2021-05-22
思路:
使用socket传输文件过程中,如果单次传输每次只能发送一部分数据,如果针对大文件,一次传输肯定是不行的,所以需要我们在传输的时候提前把传输内容的大小先发送给客户端,在客户端循环接收数据即可。
代码部分:
一、服务器
#!/usr/bin/env python#-*- coding:utf-8 -*-#environment:2.7import os,json,time,socketsk = socket.socket()ip_port=('127.0.0.1',9600)sk.bind(ip_port)sk.listen(5)file_path = '/root/update/123.txt'file_name = file_path.rsplit(os.sep,1)[1] file_size = os.path.getsize(file_path) #获取文件内容大小#发送给客户端的头部信息header_data = { 'file_name': file_name, 'file_size': file_size, 'date': time.strftime('%Y-%m-%d %X',time.localtime()), 'charset': 'utf-8'}while True: conn, addr = sk.accept() print("%s:%s is connect"% addr) request_data = conn.recv(1024) print(request_data) # 把头部内容发送过去 conn.send(json.dumps(header_data)) request_data1 = conn.recv(1024) print(request_data1) f = open(file_path,'r') content = f.read() #发送文件内容 conn.sendall(content) conn.close()二、客户端
备注:在接收服务器端发送来的文件也按照判断每次接收数据的大小来考虑,大致思路如下
res = ''recive_size = 0while recive_size <= res_size: data = sk.recv(1024) recive_size += len(data) res += dataelse: print(res) print('done'.center(40,'='))以上这篇使用python socket分发大文件的实现方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例讲述了Python实现大文件排序的方法。分享给大家供大家参考。具体实现方法如下:importgzipimportosfrommultiprocessin
php实现断点续传,就需要把大文件分割成多个小文件,然后单个上传。传完后在合并。│merge.php–合并文件脚本│merge.zip–合并后文件│socket
前几天已经讲过了UDP协议下大文件传输的python实现代码,今天再实现TCP协议下大文件传输的python实现代码。TCP和UDP的实现过程还是比较不一样的。
本文实例讲述了python通过socket查询whois的方法。分享给大家供大家参考。具体实现方法如下:importsockets=socket.socket(
本文实例讲述了python简单读取大文件的方法。分享给大家供大家参考,具体如下:Python读取大文件(GB级别)采用的办法很简单:withopen(...)a