一、python学习之面向对象高级语法部分
1、静态方法
例如:
1 class Dog(object): 2 3 def __init__(self,name): 4 self.name = name 5 6 @staticmethod 7 def eat(): 8 print(" is eating") 9 10 11 12 d = Dog("ChenRonghua") 13 d.eat()
1)实现
@staticmethod装饰器即可把其装饰的方法变为一个静态方法
2)特点
静态方法是不可以访问实例变量或类变量
3)解决方案
1. 调用时主动传递实例本身给eat方法,即d.eat(d)
2. 在eat方法中去掉self参数,但这也意味着,在eat中不能通过self.调用实例中的其它变量了
2、类方法
例如:
class
Dog(
object
):
name
=
"我是类变量"
def
__init__(
self
,name):
self
.name
=
name
@classmethod
def
eat(
self
):
print
(
"%s is eating"
%
self
.name)
d
=
Dog(
"ChenRonghua"
)
d.eat()
1)实现
类方法通过@classmethod装饰器实现
2)特点
类方法只能访问类变量,不能访问实例变量
3、属性方法
例如:
class
Dog(
object
):
def
__init__(
self
,name):
self
.name
=
name
@property
def
eat(
self
):
print
(
" %s is eating"
%
self
.name)
d
=
Dog(
"ChenRonghua"
)
d.eat()
1)实现
@property把一个方法变成一个静态属性
2)特点
方法变成了一个静态属性,可以直接当做静态属性使用而不能在当做方法使用
4、反射
1)反射的定义
根据字符串的形式去某个对象中操作成员,具体包括:
根据字符串的形式去一个对象中寻找成员
根据字符串的形式去一个对象中设置成员
根据字符串的形式去一个对象中删除成员
根据字符串的形式去一个对象中判断成员是否存在
2)反射的函数
getattr(object,name[,default])
根据字符串的形式去一个对象中寻找成员
setattr(object, name, value)
根据字符串的形式去一个对象中设置成员
delattr(object, name)
根据字符串的形式去一个对象中删除成员
hasattr(object, name)
根据字符串的形式去一个对象中判断成员是否存在
5、异常处理
1)常用异常:
AttributeError 试图访问一个对象没有的树形,比如foo.x,但是foo没有属性x
IOError 输入
/
输出异常;基本上是无法打开文件
ImportError 无法引入模块或包;基本上是路径问题或名称错误
IndentationError 语法错误(的子类) ;代码没有正确对齐
IndexError 下标索引超出序列边界,比如当x只有三个元素,却试图访问x[
5
]
KeyError 试图访问字典里不存在的键
KeyboardInterrupt Ctrl
+
C被按下
NameError 使用一个还未被赋予对象的变量
SyntaxError Python代码非法,代码不能编译(个人认为这是语法错误,写错了)
TypeError 传入对象类型与要求的不符合
UnboundLocalError 试图访问一个还未被设置的局部变量,基本上是由于另有一个同名的全局变量,
导致你以为正在访问它
ValueError 传入一个调用者不期望的值,即使值的类型是正确的
2)更多异常:
ArithmeticError
AssertionError
AttributeError
BaseException
BufferError
BytesWarning
DeprecationWarning
EnvironmentError
EOFError
Exception
FloatingPointError
FutureWarning
GeneratorExit
ImportError
ImportWarning
IndentationError
IndexError
IOError
KeyboardInterrupt
KeyError
LookupError
MemoryError
NameError
NotImplementedError
OSError
OverflowError
PendingDeprecationWarning
ReferenceError
RuntimeError
RuntimeWarning
StandardError
StopIteration
SyntaxError
SyntaxWarning
SystemError
SystemExit
TabError
TypeError
UnboundLocalError
UnicodeDecodeError
UnicodeEncodeError
UnicodeError
UnicodeTranslateError
UnicodeWarning
UserWarning
ValueError
Warning
ZeroDivisionError
3)异常实现方式
try
:
# 主代码块
pass
except
KeyError,e:
# 异常时,执行该块
pass
else
:
# 主代码块执行完,执行该块
pass
finally
:
# 无论异常与否,最终执行该块
pass
二、python学习之scoket编程基础
1、scoket解释
socket通常也称作"套接字",用于描述IP地址和端口,是一个通信链的句柄,应用程序通常通过"套接字"向网络发出请求或者应答网络请求。
2、socket和file的区别:
file模块是针对某个指定文件进行【打开】【读写】【关闭】
socket模块是针对 服务器端 和 客户端Socket 进行【打开】【读写】【关闭】
3、scoket编程思想
1)TCP服务端
- 创建套接字,绑定套接字到本地IP与端口
- 开始监听连接
- 进入循环,不断接受客户端的连接请求
- 然后接收传来的数据,并发送给对方数据
- 传输完毕后,关闭套接字
2)TCP客户端
- 创建套接字,连接远端地址
- 连接后发送数据和接收数据
- 传输完毕后,关闭套接字
4、代码实现
1)服务器端
import
socket
#服务器端
server
=
socket.socket()
server.bind((
‘localhost‘
,
6969
))
#绑定要监听的端口
server.listen()
#监听
print
(
"等待连接。。。"
)
conn,addr
=
server.accept()
#等待接收
print
(conn,addr)
server.close()
2) 客户端
import
socket
#客户端
client
=
socket.socket()
#声明socket类型,同时生成socket连接对象
client.connect((
‘localhost‘
,
6969
))
client.close()
先运行服务器端,然后再运行客户端
服务器端:
1 2 3 4 5 6 7 8 9 |
|
客户端:
1 2 3 4 5 |
|