pickle,load :切记:如果load的是个对象的话,必须导入构建这个对象的类

 

 
封装
类和对象的关系:
每个对象里都有一个类对象指针,指向类
 

 
继承:支持单继承和多继承
print(
'''
继承顺序:ABCDEF 先左后右,深度优先,最后找祖宗
F
/ \
C E
| |
B D
\ /
A
''')
class F:
def f3(self):
print("F f3")
class C(F):
def f1(self):
print("C f1")
class E(F):
def f1(self):
print("E f1")
class B(C):
def f2(self):
print("B f2")
class D(E):
def f2(self):
print("D f2")
def f1(self):
print(D f1")
def f3(self):
print("D f3")
class A(B,D):
pass
obj=A()
print("B和D继承关系:先左后右")
obj.f2()
print("C和D继承关系:深度优先")
obj.f1()
print("F和D的继承关系:如果有共同的祖宗的话最后找祖宗")
obj.f3()
继承顺序:ABCDEF
    F
  /   \ 
C       E
|         |
B       D
  \   /
    A
 
B和D继承关系:先左后右
B f2
C和D继承关系:深度优先
C f1
F和D的继承关系:如果有共同的祖宗的话最后找祖宗
D f3
 

 
多态:多种形态,多种数据类型,python原生支持多态,别的语言不支持
但是这样python有个缺点:查看源码的时候不是很方便
 
 

 
面向对象中类成员:
字段:
静态字段:保存在类里  把所有对象里相同的字段放到类里 叫静态字段  在程序加载的时候就会创建
普通字段:保存在对象里  
一般情况:普通字段只能用对象访问,静态字段用类访问,万不得已可以用对象访问(对象里有类对象指针,可以找到类里的字段)
原则:自己访问自己的
 
        
class Province:
country=中国" #静态字段
def __init__(self,province):
self.province=province #普通字段
print("#######一般情况:自己访问自己的字段######")
sx=Province("山西")
print(Province.country)
print(sx.province)
print("#####python不一般:对象里的字段只能用对象访问,静态字段用类访问(万不得已的时候可以用对象访问)#####")
print(sx.country)
#######一般情况:自己访问自己的字段######
中国
山西
#####python不一般:对象里的字段只能用对象访问,静态字段用类访问(万不得已的时候可以用对象访问)#####
中国
 
 

 
 
方法:所有方法属于类
   普通方法:由对象调用使用的                                  至少一个self
   静态方法:由类调用使用的   =  python函数     任意参数
   类方法   : 由类执行                                                至少一个cls
class Province:
country="中国"
def __init__(self,province):
self.province=province
def show(self): #普通方法
print(self.province)
@staticmethod
def static(): #静态方法
print(123) Province.static()
123
class Province:
country="中国"
def __init__(self,province):
self.province=province
def show(self): #普通方法
print(self.province)
@classmethod
def class_func(cls): #类方法 cls是class的缩写,代指类 类似self代指对象
sx=cls("山西")
sx.show()
Province.class_func()
 
山西
 

 
属性:调用时可以去掉括号,让方法以字段的形式进行访问
具有方法的写作形式,具有字段的访问形式
 
class Province:
country="中国"
def __init__(self,province):
self.province=province
@property
def show(self): #属性
return self.province sx=Province("山西")
province=sx.show
print(province)
山西
class C:
def __init__(self,total):
self.total=total
@property
def f1(self):
return self.total
@f1.setter
def f1(self,value):
print(value)
@f1.deleter
def f1(self):
print("i am del") c=C(101)
ret = c.f1
print(ret)
c.f1=100
del c.f1
101
100
i am del
class C:
def __init__(self,total):
self.total=total
def f1(self):
return self.total
def f2(self,value):
print(value)
def f3(self):
print("i am del")
Foo=property(fget=f1,fset=f2,fdel=f3)
c=C(101)
ret = c.Foo
print(ret)
c.Foo = 100
del c.Foo
101
100
i am del
 

 
成员修饰符:
字段:
私有字段: 字段名前加两个下划线(self.__name) 只有自己本身self可以用
私有方法
私有属性
class C1:
__age=18
def __init__(self,name):
self.__name=name
def f1(self):
print(self.__name)
@staticmethod
def f3():
print(C1.__age) class C2(C1):
def f2(self):
print(self.__name) p=C1("jack")
p.f1()
# p2=C2("zy")
# p2.f2() #错误
p.f3()
# print(C1.__age) #错误
# print(p.__name) #错误
print("####以下是非一般情况,尽量别用####")
print(p._C1__name)
print(p._C1__age)
jack
18
####以下是非一般情况,尽量别用####
jack
18
class C1:
def __f1(self):
print("123")
def f2(self):
self.__f1() p=C1()
p.f2()
p._C1__f1() #非一般情况,最后别用
# p.__f1() #错误
123
123
class C1:
@property
def __f1(self):
print("123")
def f2(self):
self.__f1 p=C1()
p.f2()
p._C1__f1 #非一般情况,最后别用
# p.__f1 #错误
123
123
 
特殊方法:
__init__:构造方法                                            类()
__del__:析构方法
__call__:                                              对象()  类()()
__str__:    __str__方法return返回值                    对象
__dict__:  获取对象(或类)中封装的所有数据    
__getitem__ :
__setitem__ :
__delitem__ :
__iter__ :
class C1:
'''
这是个使用__str__方法的类
也是个使用__call__方法的类
'''
def __init__(self,name):
self.name = name
def __str__(self):
return self.name
def __call__(self):
print("执行call方法")
class C2:
pass
print(C1.__doc__)
print("#####没有__str__方法#####")
p3=C2()
print(p3)
print("#####__str__第一种方式#####")
p1=C1('alex')
print(p1)
print("#####__str__第二种方式#####")
p2=C1('jack')
ret = str(p2)
print(ret)
print("#####__call__#####")
p1()
    这是个使用__str__方法的类
    也是个使用__call__方法的类
    
#####没有__str__方法#####
<__main__.C2 object at 0x101976d68>
#####__str__第一种方式#####
alex
#####__str__第二种方式#####
jack
#####__call__#####
执行call方法
class C1:
def __init__(self,name,age):
self.name = name
self.age = age p1=C1('alex',18)
print(p1.__dict__)
{'name': 'alex', 'age': 18}
class C1:
def __init__(self,name,age):
self.name = name
self.age = age print(C1.__dict__) #一般不用
{'__weakref__': <attribute '__weakref__' of 'C1' objects>, '__doc__': None, '__dict__': <attribute '__dict__' of 'C1' objects>, '__init__': <function C1.__init__ at 0x10217a6a8>, '__module__': '__main__'}
dic={}
class C1:
def __getitem__(self, item):
print(dic[item])
def __setitem__(self, key, value):
dic[key]=value
def __delitem__(self, key):
del dic[key]
obj=C1()
obj[0]=00
obj[1]=11
obj[2]=22
obj["jack"]="张士杰"
del obj[1]
obj[0]
obj[2]
obj["jack"]
00
22
张士杰
class Foo:
def __iter__(self):
for i in range(5):
yield i obj=Foo()
for item in obj:
print(item)
0
1
2
3
4
 
 
 
 
 
 

python成长之路——第八天的更多相关文章

  1. 我的Python成长之路---第八天---Python基础(25)---2016年3月5日(晴)

    多进程 multiprocessing模块 multiprocessing模块提供了一个Process类来代表一个进程对象 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 ...

  2. 我的Python成长之路---第八天---Python基础(24)---2016年3月5日(晴)

    多线程编程 什么是多线程,线程是操作系统能够进行运算调度的最小单位.他包含在进程之中,是进程中的实际运作单位.线程是进程中一个单顺序的空值六,一个进程可以并发多个线程,每个线程可以并行处理不同的任务. ...

  3. 我的Python成长之路---第八天---Python基础(23)---2016年3月5日(晴)

    socketserver 之前讲道德socket模块是单进程的,只能接受一个客户端的连接和请求,只有当该客户端断开的之后才能再接受来自其他客户端的连接和请求.当然我们也可以通过python的多线程等模 ...

  4. 【Python成长之路】Python爬虫 --requests库爬取网站乱码(\xe4\xb8\xb0\xe5\xa)的解决方法【华为云分享】

    [写在前面] 在用requests库对自己的CSDN个人博客(https://blog.csdn.net/yuzipeng)进行爬取时,发现乱码报错(\xe4\xb8\xb0\xe5\xaf\x8c\ ...

  5. (转)Python成长之路【第九篇】:Python基础之面向对象

    一.三大编程范式 正本清源一:有人说,函数式编程就是用函数编程-->错误1 编程范式即编程的方法论,标识一种编程风格 大家学习了基本的Python语法后,大家就可以写Python代码了,然后每个 ...

  6. 【Python成长之路】装逼的一行代码:快速共享文件

    [Python成长之路]装逼的一行代码:快速共享文件 2019-10-26 15:30:05 华为云 阅读数 335 文章标签: Python编程编程语言程序员Python开发 更多 分类专栏: 技术 ...

  7. python成长之路第三篇(1)_初识函数

    目录: 函数 为什么要使用函数 什么是函数 函数的返回值 文档化函数 函数传参数 文件操作(二) 1.文件操作的步骤 2.文件的内置方法 函数: 一.为什么要使用函数 在日常写代码中,我们会发现有很多 ...

  8. 我的Python成长之路---第一天---Python基础(1)---2015年12月26日(雾霾)

    2015年12月26日是个特别的日子,我的Python成之路迈出第一步.见到了心目中的Python大神(Alex),也认识到了新的志向相投的伙伴,非常开心. 尽管之前看过一些Python的视频.书,算 ...

  9. Python成长之路第二篇(1)_数据类型内置函数用法

    数据类型内置函数用法int 关于内置方法是非常的多这里呢做了一下总结 (1)__abs__(...)返回x的绝对值 #返回x的绝对值!!!都是双下划线 x.__abs__() <==> a ...

随机推荐

  1. php保留小数格式的多种方法

    php保留小数格式,定义小数格式,小数点,位数,小数位数: 方法一:(推荐)bcmul(1000.90,1,2);//两个数相乘1000.90*1, 保留两位小数点(无四舍五入)<返回strin ...

  2. Java中synchronized注意点

    之前一直以为 synchronized 加在方法前面就只有一个线程能访问了,项目中碰到一个问题,一个类的不同对象,同时访问加了 synchronized的方法 同样是可以访问的,那是因为 synchr ...

  3. cocos2dx CCControlSlider

    有的同学建议先上图,好吧,先上效果图 再看代码,创建了两个CCControlSlider在主窗口中 // on "init" you need to initialize your ...

  4. HDU5280 Senior&#39;s Array(简单DP)

    题目链接:pid=5280">传送门 题意: 给定一个长度为n的序列,和一个改动的值p,必须从原序列中选一个位置改动成p, 求改动后的区间和的最大值. 分析: 枚举位置+最大区间和. ...

  5. HTML5新特性之CSS+HTML5实例

    1.新的DOCTYPE和字符集 HTML5的一项准则就是化繁为简,Web页面的DOCTYPE被极大的简化. <!DOCTYPE html> 同时字符集声明也被简化了: <meta c ...

  6. eclipse自动生成的appcompat_v7出错

    用eclipse新建Android工程时,自动生成的appcompat_v7出错,有个红色交叉,而且新建的Android工程有一个红色感叹号. 这时你去看看你新建的Android工程是不是没有生成R文 ...

  7. JSP 和 Servlet 有哪些相同点和不同点, 他们之间的联系是什么?

    jsp和servlet的区别和联系:1.jsp经编译后就变成了Servlet.(JSP的本质就是Servlet,JVM只能识别java的类,不能识别JSP的代码,Web容器将JSP的代码编译成JVM能 ...

  8. Java调用R——rJava的安装和配置

    rJava是Java通过JRI调用R所要安装的包.配置起来比较麻烦,我参考网上进行配置,使用rJava包中example里面的示例测试,控制台显示: Cannot find JRI native li ...

  9. #pragma pack(push,1)与#pragma pack(pop)

    这是给编译器用的参数设置,有关结构体字节对齐方式设置, #pragma pack是指定数据在内存中的对齐方式. #pragma pack (n)             作用:C编译器将按照n个字节对 ...

  10. 青蛙跳台阶问题——剑指offer

    题目:一只青蛙一次可以跳上1级台阶,也可以跳上2级台阶,求该青蛙跳上一个n级台阶总共有多少中跳法. http://www.nowcoder.com/books/coding-interviews?pa ...