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. Python GUI开发环境的搭建

    原文:Python GUI开发环境的搭建 最近对Python的开发又来了兴趣,对于Python的开发一直停留在一个表面层的认识,玩的部分比较大. Python的入手简单,语法让人爱不释手,在网络通信方 ...

  2. Linux2.6中的Slab层

          还记得一个进程创建的时候是什么给它分配的“进程描述符”吗?没错,是slab分配器,那么,这个slab分配器是个什么东西呢?       分配和释放数据结构是所有内核中最普遍的操作之一.为了 ...

  3. java设计模式(二)单例模式 建造者模式

    (三)单例模式 单例模式应该是最常见的设计模式,作用是保证在JVM中,该对象仅仅有一个实例存在. 长处:1.降低某些创建比較频繁的或者比較大型的对象的系统开销. 2.省去了new操作符,减少系统内存使 ...

  4. centos6.5设备mysql5.6

    1. 首先检查版本号number # uname -a 要么 # cat /etc/redhat-release CentOS release 6.6 (Final) 2. 下载并安装Mysql的yu ...

  5. 设置android:supportsRtl=&quot;true&quot;无效问题

     今天解bug时,遇到这样一个问题:   问题描写叙述:切换系统语言为阿拉伯文时,actionbar布局没有变为从右向左排列.   于是,我在Androidmanifest.xml文件里的 appli ...

  6. POJ 3376 Finding Palindromes(扩展kmp+trie)

    题目链接:http://poj.org/problem?id=3376 题意:给你n个字符串m1.m2.m3...mn 求S = mimj(1=<i,j<=n)是回文串的数量 思路:我们考 ...

  7. 多线程笔记--原子操作Interlocked系列函数

    前面写了一个多线程报数的功能,为了描述方便和代码简洁起见,只输出最后的报数结果来观察程序运行结果.这非常类似一个网站的客户访问统计,每个用户登录用一个线程模拟,线程运行时将一个表示计数的变量递增.程序 ...

  8. jquery的extend()函数

    extend()是在写插件的过程中常用的方法,该方法有一些重载原型. 1.该方法的原型是: extend(dest,src1,src2,src3...); 它的含义是将src1,src2,src3.. ...

  9. ThinkPHP第十四天(显示TRACE界面配置,关联模型详解定义)

    1.显示TRACE界面,首选需要在显示模版界面,$this->display(),然后需要在配置文件中配置 SHOW_PAGE_TRACE => true 2.关联模型使用 主表以user ...

  10. Asp.net 网站发布之文件系统方式

    1.选中项目右键→发布方式选[文件系统]→点击发布 2.打开[Internet 信息服务(IIS)管理器] 默认网站(Default Web Site)→添加应用程序 填写[别名],[物理路径]选择上 ...