python實現(xiàn)TCP文件接收發(fā)送
更新時間:2021年09月02日 13:01:52 作者:_在水一方
這篇文章主要為大家詳細介紹了python實現(xiàn)TCP文件接收發(fā)送,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
本文實例為大家分享了python實現(xiàn)TCP文件接收發(fā)送的具體代碼,供大家參考,具體內容如下
下一篇分享:udp收發(fā)的實現(xiàn)
先運行服務器端打開接收,在運行客服端發(fā)送文件
還有記得改一下ip喲
1、發(fā)送
根據(jù)自己需求修改,簡單局域網(wǎng)下完成文件收發(fā)
客戶端
# 由客戶端向服務器傳數(shù)據(jù),文件 import socket import tqdm import os def send(filename): # 傳輸數(shù)據(jù)間隔符 SEPARATOR = '<SEPARATOR>' # 服務器信息 host = '127.0.0.1' port =1234 # 文件緩沖區(qū) Buffersize = 4096*10 # 傳輸文件名字 filename = filename # 文件大小 file_size = os.path.getsize(filename) # 創(chuàng)建socket鏈接 s = socket.socket() print(f'服務器連接中{host}:{port}') s.connect((host, port)) print('與服務器連接成功') # 發(fā)送文件名字和文件大小,必須進行編碼處理 s.send(f'{filename}{SEPARATOR}{file_size}'.encode()) # 文件傳輸 progress = tqdm.tqdm(range(file_size), f'發(fā)送{filename}', unit='B', unit_divisor=1024) with open(filename,'rb') as f : # 讀取文件 for _ in progress: bytes_read = f.read(Buffersize) if not bytes_read: break # sendall 確保網(wǎng)絡忙碌的時候,數(shù)據(jù)仍然可以傳輸 s.sendall(bytes_read) progress.update(len(bytes_read)) # 關閉資源 s.close() if __name__ == '__main__': filename = input('請輸入文件名:') send(filename)
2、接收
服務器端
import socket import tqdm import os import threading def received(): # 設置服務器的ip和 port # 服務器信息 sever_host = '127.0.0.1' sever_port =1234 # 傳輸數(shù)據(jù)間隔符 SEPARATOR = '<SEPARATOR>' # 文件緩沖區(qū) Buffersize = 4096*10 s = socket.socket() s.bind((sever_host, sever_port)) # 設置監(jiān)聽數(shù) s.listen(128) print(f'服務器監(jiān)聽{sever_host}:{sever_port}') # 接收客戶端連接 client_socket, address = s.accept() # 打印客戶端ip print(f'客戶端{address}連接') # 接收客戶端信息 received = client_socket.recv(Buffersize).decode() filename ,file_size = received.split(SEPARATOR) # 獲取文件的名字,大小 filename = os.path.basename(filename) file_size = int(file_size) # 文件接收處理 progress = tqdm.tqdm(range(file_size), f'接收{filename}', unit='B', unit_divisor=1024, unit_scale=True) with open('8_18_'+filename,'wb') as f: for _ in progress: # 從客戶端讀取數(shù)據(jù) bytes_read = client_socket.recv(Buffersize) # 如果沒有數(shù)據(jù)傳輸內容 if not bytes_read: break # 讀取寫入 f.write(bytes_read) # 更新進度條 progress.update(len(bytes_read)) # 關閉資源 client_socket.close() s.close() if __name__ == '__main__': received()
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
Python配置文件解析模塊ConfigParser使用實例
這篇文章主要介紹了Python配置文件解析模塊ConfigParser使用實例,本文講解了figParser簡介、ConfigParser 初始工作、ConfigParser 常用方法、ConfigParser使用實例等內容,需要的朋友可以參考下2015-04-04Mac上Python使用ffmpeg完美解決方案(避坑必看!)
ffmpeg是一個強大的開源命令行多媒體處理工具,下面這篇文章主要給大家介紹了關于Mac上Python使用ffmpeg完美解決方案的相關資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下2023-02-02