上节课程回顾:
静态变量:与类无关,不能访问类里的任何属性和方法。
类方法:只能访问类变量。
属性:把一个方法变成静态属性,
反射:
__new__:先于__init__执行;
__call__:
class Foo(object):
def __call__()
print "call" #这是什么??? #Foo() #后面跟一个括号是实例化
Foo()() #后面跟2个括号是执行call方法
抓住异常:
try
......
except (ValueError,KeyError), e #in 2.7
except (ValueError,KeyError) as e #in 3.x
else: #没发生异常就执行
finally #无论如何都执行
raise (触发自己写的异常)
except Exception as e #放在异常处理最后面,
异常处理:
断言(assert): 返回为假就不往下执行了。(例如银行转账,要确保正确才能转账)
例如:assert type(XXX) is str
本节内容:
一.动态导入模块
import importlib __import__('import_lib.metaclass') #这是解释器自己内部用的
#importlib.import_module('import_lib.metaclass') #与上面这句效果一样,官方建议用这个
#__metaclass__用来定义这个类以怎样的形式被创建(我们很少用到)
本节课内容:
1.socket :网络上的数据收发。
tcp/ip send ,recv
udp
family address (地址簇):
AF.INET (ipv4)
AF.INET6
AF.UNIX (local
socket protocol type (协议类型)
sock.SOCK_STREAM (tcp/ip)
sock.SOCK_DGRAM
服务端步骤:
server = socket.socket(AF.INET,sock.SOCK_STREAM)
server.bind(localhost,9999)
server.listen()
while True:
conn, addr = server.accept() #阻塞
while True:
print("new conn", addr)
data = conn.recv(1024) #不应该超过8192(8k)#recv默认是阻塞的
if not data:
break #客户端已断开,conn.recv收到的就是空数据,
print(data)
conn.send(data.upper())
客户端步骤:
client = socket.socket()
client.connect(serverip,9999)
client.send(data)
client.recv(data)
import socket
import os
server = socket.socket()
server.bind(('localhost',1111)) server.listen() while True:
conn,addr = server.accept()
print("new conn:",addr)
while True:
data = conn.recv(1024)
if not data:
print("客户端已断开")
break
print("执行指令:", data)
cmd_res = os.popen(data.decode()).read() #接收字符串,执行结果也是字符串
conn.send(cmd_res.encode("utf-8")) server.close()
import socket
client = socket.socket()
client.connect(('localhost',1111)) while True:
cmd = input(">>:").strip() #cmd = input(b">>:").strip()如果前面直接加b,则只能传英文
if len(cmd) == 0 : continue
client.send(cmd.encode())
cmd_res = client.recv(1024) print(cmd_res.decode()) client.close()
运行结果:
>>:ipconfig Windows IP 配置 以太网适配器 以太网: 媒体状态 . . . . . . . . . . . . : 媒体已断开连接
连接特定的 DNS 后缀 . . . . . . . : 无线局域网适配器 本地连接* 2: 媒体状态 . . . . . . . . . . . . : 媒体已断开连接
连接特定的 DNS 后缀 . . . . . . . : 无线局域网适配器 本地连接* 4: 媒体状态 . . . . . . . . . . . . : 媒体已断开连接
连接特定的 DNS 后缀 . . . . . . . : 无线局域网适配器 本地连接* 5: 媒体状态 . . . . . . . . . . . . : 媒体已断开连接
连接特定的 DNS 后缀 . . . . . . . : 无线局域网适配器 WLAN: 连接特定的 DNS 后缀 . . . . . . . : workgroup
本地链接 IPv6 地址. . . . . . . . : fe80::1585:c613:2947:4558%17
IPv4 地址 . . . . . . . . . . . . : 172.25.81.3
子网掩码 . . . . . . . . . . . . : 255.255.0.0
默认网关. . . . . . . . . . . . . : 172.25.81.1
注:1.服务器与客户端解码编码四次。
2.(1024)传输与接收数据大小的问题:
缓冲区:比如一次只能接收1024,发送了2000,省下的900左右会存在缓冲区了,等下次发送,但这样会乱,怎么解决?
答:多收几次。
问:但具体多收几次呢?
答:服务器自己计算一下自己将要给客户端多大的数据,几次能接收完,先把次数发给客户端。