import socket
import struct
sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
sock.connect(('localhost', 10000))
values = (1, 'ab', 2.7)
packer = struct.Struct('I 2s f')
packed_data = packer.pack(*values)
try:
sock.sendall(packed_data)
finally:
sock.close()
有个模块叫struct,可以自定义结构体,可以这样发送代码。
try:
import cPickle as pickle
except:
import pickle
class AA():
def a(self):
print "123"
ddd = AA()
data = pickle.dumps(ddd)
还有个模块叫pickle,可以打包任何python对象,打包的结果也可以拿到套接字里发。
可以转换为字符串,比如反引号或者repr函数,由字符串变成对象,可以用eval函数
实现序列化接口