python使用socket實(shí)現(xiàn)圖像傳輸功能
在python中使用socket進(jìn)行l(wèi)inux服務(wù)器與win10主機(jī)間的圖像傳輸,供大家參考,具體內(nèi)容如下
前提:服務(wù)器與主機(jī)需要在同一局域網(wǎng)內(nèi)
使用方法:
(1)分別將下面兩段代碼存入對(duì)應(yīng)位置
(2)先運(yùn)行服務(wù)器端代碼,顯示Wait for Connection.....................
(3)在運(yùn)行客戶端代碼,顯示input the file:
(4)在(3)的輸出后面復(fù)制想需要傳輸?shù)膱D像地址即可
1.服務(wù)器端(我的是Linux服務(wù)器)
# 服務(wù)器端server.py
import socket
import os
import sys
import struct
def socket_service_image():
try:
s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
s.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)
# s.bind(('127.0.0.1', 8001))
s.bind(('改成你的服務(wù)器ip地址', 8001))
s.listen(10)
except socket.error as msg:
print(msg)
sys.exit(1)
print("Wait for Connection.....................")
while True:
sock, addr = s.accept() # addr是一個(gè)元組(ip,port)
deal_image(sock, addr)
def deal_image(sock, addr):
print("Accept connection from {0}".format(addr)) # 查看發(fā)送端的ip和端口
while True:
fileinfo_size = struct.calcsize('128sq')
buf = sock.recv(fileinfo_size) # 接收?qǐng)D片名
if buf:
filename, filesize = struct.unpack('128sq', buf)
fn = filename.decode().strip('\x00')
new_filename = os.path.join(r'G:\reseive_images\\' + fn) # 在服務(wù)器端新建圖片名(可以不用新建的,直接用原來的也行,只要客戶端和服務(wù)器不是同一個(gè)系統(tǒng)或接收到的圖片和原圖片不在一個(gè)文件夾下)
recvd_size = 0
fp = open(new_filename, 'wb')
while not recvd_size == filesize:
if filesize - recvd_size > 1024:
data = sock.recv(1024)
recvd_size += len(data)
else:
data = sock.recv(1024)
recvd_size = filesize
fp.write(data) # 寫入圖片數(shù)據(jù)
fp.close()
sock.close()
break
if __name__ == '__main__':
socket_service_image()
2.客戶端(我的是win10主機(jī))
# 客戶端client.py
import socket
import os
import sys
import struct
def sock_client_image():
while True:
try:
s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
s.connect(('改成服務(wù)器ip地址', 8001)) # 服務(wù)器和客戶端在不同的系統(tǒng)或不同的主機(jī)下時(shí)使用的ip和端口,首先要查看服務(wù)器所在的系統(tǒng)網(wǎng)卡的ip
# s.connect(('127.0.0.1', 8001)) #服務(wù)器和客戶端都在一個(gè)系統(tǒng)下時(shí)使用的ip和端口
except socket.error as msg:
print(msg)
print(sys.exit(1))
filepath = input('input the file: ') # 輸入當(dāng)前目錄下的圖片名 xxx.jpg
fhead = struct.pack(b'128sq', bytes(os.path.basename(filepath), encoding='utf-8'),
os.stat(filepath).st_size) # 將xxx.jpg以128sq的格式打包
s.send(fhead)
fp = open(filepath, 'rb') # 打開要傳輸?shù)膱D片
while True:
data = fp.read(1024) # 讀入圖片數(shù)據(jù)
if not data:
print('{0} send over...'.format(filepath))
break
s.send(data) # 以二進(jìn)制格式發(fā)送圖片數(shù)據(jù)
s.close()
# break #循環(huán)發(fā)送
if __name__ == '__main__':
sock_client_image()
以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Python Pandas分組聚合的實(shí)現(xiàn)方法
這篇文章主要介紹了Python Pandas分組聚合的實(shí)現(xiàn)方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-07-07
用Python爬取LOL所有的英雄信息以及英雄皮膚的示例代碼
這篇文章主要介紹了用Python爬取LOL所有的英雄信息以及英雄皮膚的示例代碼,主要分為兩部分,獲取網(wǎng)頁上數(shù)據(jù)和圖片保存到本地等,感興趣的可以了解一下2020-07-07
Python學(xué)習(xí)筆記之字典,元組,布爾類型和讀寫文件
這篇文章主要為大家詳細(xì)介紹了Python的字典,元組,布爾類型和讀寫文件,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助2022-02-02
使用 PyTorch 實(shí)現(xiàn) MLP 并在 MNIST 數(shù)據(jù)集上驗(yàn)證方式
今天小編就為大家分享一篇使用 PyTorch 實(shí)現(xiàn) MLP 并在 MNIST 數(shù)據(jù)集上驗(yàn)證方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-01-01
PyTorch如何使用embedding對(duì)特征向量進(jìn)行嵌入
這篇文章主要介紹了PyTorch如何使用embedding對(duì)特征向量進(jìn)行嵌入問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-02-02
使用Python實(shí)現(xiàn)PDF與SVG互轉(zhuǎn)
SVG(可縮放矢量圖形)和PDF(便攜式文檔格式)是兩種常見且廣泛使用的文件格式,本文將詳細(xì)介紹如何使用?Python?實(shí)現(xiàn)?SVG?和?PDF?之間的相互轉(zhuǎn)換,感興趣的可以了解下2025-02-02

