Python2和Python3的区别
一、语法
- Python2 中使用
print
输出语句,Python3 中去掉print
语句,使用print()
代替; - Python2 中使用内建函数
raw_input()
,Python3 中去掉raw_input()
,使用input()
代替; - Python2 中支持
<>
作为!=
的同义词,Python3 中只支持!=
,不再支持<>
; - Python2 中使用
range
生成list
对象,xrange
创建生成器,Python3 中使用range
替代xrange
,生成列表需要显式调用;例:
>>> list(range(5))
[0,1,2,3,4]
二、编码
Python2 中有基于ASCII的 str()
类型,可使用unicode()
函数转成unicode
类型,但没有byte类型;Python3 中有unicode(utf-8)
字符串,以及两个字节类bytes
和bytearrays
。
三、数据类型
Python3 中去除long
类型,只剩下一种整型int
,对应Python2 中的long
;新增bytes
类型,对应Python2 中的八位串。
四、除法运算
Python2 中除法运算,整数相除会将小数部分忽略掉;Python3 中整数相除,结果为浮点数。
元编程
给函数添加一个包装,主要目标是创建函数和类,并用它来操纵代码,主要技术是使用装饰器、类装饰器和元类。
一个装饰器就是一个函数,接受一个函数作为参数并返回一个新的函数,例:
@timethis
def countdown(n):
pass
等价于:
def countdown(n):
pass
countdown = timethid(countdown)
// TODO 带参数的装饰器和类装饰器
日志logging
日志级别:DEBUG
,INFO
,WARNING
,ERROR
,CRITICAL
,优先级由低到高,分别对应的函数 debug()
,info()
,warning()
,error()
,critical()
。
网络编程
套接字
两个端点的程序之间的“信息通道”,即实现不同端点上的程序通信。程序可能分布在不同的计算机上(通过网络连接),通过套接字相互发送信息。套接字包括两个:服务器套接字和客户机套接字。在创建一个服务器套接字后,让它等待连接。这样它就在某个网络地址处(IP地址和一个端口的组合)监听,直到有客户端套接字连接。连接完成后两者即可进行交互。
面向连接的套接字,即在通信之前需要建立一条连接,实现这种连接的主要协议为传输控制协议(即TCP
),创建TCP套接字需指定套接字类型为SOCK_STREAM,例:
tcpSock = socket.socket(socket.AF_INET,socket.SOCK_STREAM)
无需建立连接即可进行通讯,实现这种连接的主要协议就是用户数据报协议(即UDP
),创建UDP套接字需指定套接字类型为SOCK_DGRAM,例:
udpSock = socket.socket(socket.AF_INET,socket.SOCK_DGRAM)
服务器端套接字函数
s.bind() 绑定地址(主机,端口号对)到套接字
s.listen() 开始 TCP 监听
s.accept() 被动接受 TCP 客户的连接,(阻塞式)等待连接的到来
客户端套接字函数
s.connect() 主动初始化 TCP 服务器连接
s.connect_ex() connect()函数的扩展版本,出错时返回出错码,而不是抛异常
公共用途的套接字函数
s.recv() 接收 TCP 数据
s.send() 发送 TCP 数据
s.sendall() 完整发送 TCP 数据
s.recvfrom() 接收 UDP 数据
s.sendto() 发送 UDP 数据
s.getpeername() 连接到当前套接字的远端的地址
s.getsockname() 当前套接字的地址
s.getsockopt() 返回指定套接字的参数
s.setsockopt() 设置指定套接字的参数
s.close() 关闭套接字
创建 TCP 服务器
ss = socket() # 创建服务器套接字
ss.bind() # 把地址绑定到套接字上
ss.listen() # 监听连接
inf_loop: # 服务器无限循环
cs = ss.accept() # 接受客户的连接
comm_loop: # 通讯循环
cs.recv()/cs.send() # 对话(接收与发送)
cs.close() # 关闭客户套接字
ss.close() # 关闭服务器套接字(可选)
创建 TCP 客户端
cs = socket() # 创建客户套接字
cs.connect() # 尝试连接服务器
comm_loop: # 通讯循环
cs.send()/cs.recv() # 对话(发送/接收
cs.close() # 关闭客户套接字
创建 UDP 服务器
ss = socket() # 创建一个服务器套接字
ss.bind() # 绑定服务器套接字
inf_loop: # 服务器无限循环
cs = ss.recvfrom()/ss.sendto() # 对话(接收与发送)
ss.close() # 关闭服务器套接字
创建 UDP 客户端
cs = socket() # 创建客户套接字
comm_loop: # 通讯循环
cs.sendto()/cs.recvfrom() # 对话(发送/接收)
cs.close() # 关闭客户套接字
Web编程
urlparse解析URL ( 统一资源定位符)#####
>>> import urlparse
>>> r = urlparse.urlparse("http://alice:secret
@ www.hostname.com:80/% 7Ealice/python.cgi?
query=text#sample")
>>> r
ParseResult(scheme='http',
netloc='alice:secret @ www.hostname.com:80',
path='/%7Ealice/python.cgi',
params='', query=' query=text', fragment='sample')
>>> r.port
80
URL的拼合
>>> r3 = urlparse.urljoin("http://www.baidu.com","ice.html")
>>> r3
'http://www.baidu.com/ice.html'