反射

1.通过字符串的形式导入模块

2.通过字符串的形式,去模块中寻找指定函数并执行

  1. '''
  2. def f1():
  3. return 'F1'
  4.  
  5. def f2():
  6. return 'F2'
  7. '''
  8. #假设上面的是一个叫user的py文件里面的内容
  9.  
  10. #import user # user不是一个字符串,是一个文件名,无法通过字符串的形式导入
  11. DO=__import__('user') #通过字符串的形式导入模块,'user'是个字符串,实现了反射的第一个功能。
  12. r=DO.f1()
  13. print(r) #输出 F1
  14. r=getattr(DO,'f1') #在模块DO中找到名字叫做f1的函数,括号中的f1是一个字符串,返回f1函数的地址
  15. print(r()) # 输出F1,通过在r的后面加个括号来执行函数,r是一个函数地址,这就实现了反射的第二个功能。
  16. #hasattr 判断模块中是否存在字符串形式的函数
  17. #setattr(DO,'AGE',8) 给一个模块设置一个全局变量
  18. #setattr(DO,'AGE',lambda a:a+1) 给一个模块设置一个函数,后面的是lambda表达式
  19. #delattr 删除某一模块中的函数或者变量
  20. # 总结:反射就是根据字符串的形式去对象(某个模块)中操作其成员,模块是对象其中的一种。

面向对象

如果函数写在类里面就叫做方法,类名后面加个括号就是创建一个对象,面向对象不是所有情况都适用。

self是一个形式参数,python内部传递,obj=Foo() 创建obj为Foo的一个实例,obj.fetch('bb'),调用Foo中的fetch方法,这个过程默认self=obj,是一个地址,创建对象时会首先执行类中的__init__方法,他有个特殊的方法叫做构造方法。

__del__解释器销毁对象时候自动调用,特殊的名字:析构方法。

封装:使用场景,当同一类型的方法具有相同的参数,直接封装在对象中,把类当作模板创建多个对象(对象内封装的数据可以不一样)

继承:派生类和基类都有,优先在派生类中找,python类中可以同时继承多个类,先是自己,再是从左到右继承。

多态:多种形态,python语言特性本身支持多态,扩展:重载(函数名相同,参数个数不相同,python不支持,重写:派生类中重新实现基类的方法。)

查找源码的过程(self.XXXX(),从底层开始找)

执行父类的构造方式:super(当前类,self).init()            父类.__init__(self,XXX)

快速判断类执行和对象执行,self,对象调用,无self,类调用。

  1. class Provice:
  2. country='china'# 静态字段存在类中
  3. def __init__(self,name):
  4. self.Name=name# Name存在对象中
  5.  
  6. @property#特性,加上这个,表示创建一个特性,将方法伪造成为了一个字段
  7. #特性方法不能再传任何参数,除了self,用来获取
  8. def end(self):
  9. temp='%s end' % self.Name
  10. print(temp)
  11. @end.setter #表示可以给end设置值,传给value并打印出来,用来设置,但end和上面的特性end必须名字一样。
  12. def end(self,value):
  13. print(value)
  14.  
  15. def start(self):
  16. temp='%s start' % self.Name
  17. print(temp)
  18.  
  19. def show(self):# 普通方法存在类中,但普通对象可通过指针调用
  20. print('输出地方')
  21. print(self.Name,Provice.country)# 访问静态字段时用类.静态字段访问,如果是
  22. #对象自己的成员,则用自己去访问,自己的对象.自己的成员,除了类中的方法。
  23.  
  24. @classmethod #类方法
  25. def xxoo(cls): #类方法必须要有一个cls参数,全称是class,通过类去访问,参数是当前类的类名
  26. print('xxoo')
  27. print(cls)
  28.  
  29. @staticmethod #只要用这个一装饰,下面的方法将变为静态方法,没有self
  30. #静态方法属于类,执行时,用类名加方法,不用传参数,对象也可以访问,但推荐用类进行访问。
  31. def Xo():#可以有任何参数,但调用时需要一一给它传递,只是不需要self了。
  32. print('xo')
  33. # 普通方法执行时必须先需要创建对象,但静态方法不需要创建对象就直接可以去执行。
  34.  
  35. henan=Provice('河南')
  36. henan.show()
  37. Provice.xxoo()
  38. ret=Provice('HAHA')
  39. ret.start()
  40. ret.end # 调用特性方法时不需要在加括号,用来获取。
  41. ret.end='浅浅'#去执行带有 @end.setter下面的end函数,可用来修改。

成员修饰符

前面加__(两个下划线),则在外面拿不到,只能在类内部访问,在子类中也不能访问,但可以通过间接访问,通过方法。什么都不加是公有的,在外面可以访问。

在一个对象后面加括号会执行__call__方法。相当于在类后面加两个括号Foo()()会执行__call__方法。对象后面加[]会执行__getitem__方法。对象.__dict__获取对象中所有的字段。__doc__注释,print(对象)直接能输出结果是因为执行了类中的__str__方法。

断言一般用于测试

单例模式

当所有实例中封装的数据都相同时,用单例模式

  1. #单例模式----
  2. class ConnectionPool:
  3. __instance=False
  4. def __init__(self):
  5. #创建连接池需要用到的东西
  6. self.ip='1.1.1.1'
  7. self.port=3306
  8. self.pwd=''
  9. self.username='xxxx'
  10. self.conn_list=[1,2,3,4,5,6,7,8,9,10]#创建10个链接线
  11. @staticmethod
  12. def get_instance():
  13. if ConnectionPool.__instance:
  14. #如果以前创建过了,还返回以前那个,不会重新创建
  15. return ConnectionPool.__instance
  16. else:
  17. #创建一个对象并将对象赋值给静态字段__instance
  18. ConnectionPool.__instance=ConnectionPool()
  19. return ConnectionPool.__instance
  20.  
  21. def get_connection(self):
  22. #获取连接
  23. import random
  24. r=random.randrange(1,11)#随机获取一个链接线
  25. return r
  26.  
  27. pool1=ConnectionPool.get_instance()
  28. pool2=ConnectionPool.get_instance()
  29. print(pool1,pool2)#输出结果一样,地址一样,说明只是一个对象,避免了重复创建,单例模式
  30. #<__main__.ConnectionPool object at 0x000001EE554C9198> <__main__.ConnectionPool object at 0x000001EE554C9198>

网络编程

socket基于TCP、IP(套接字) 客户端 服务端,所有的客户端都去连接服务端,服务端先运行起来,ip、port(端口)等待别人来链接

socketserver 并发处理多个客户端请求,使用:1、创建类,必须继承2、handle方法  3、server_forever

进程

优点:利用电脑的多核优势(能够同时进行多个操作)  缺点:浪费计算机的资源内存(重新开辟内存空间),进程不是越多越好,cpu个数=进程个数最好。

线程

优点:共享内存,IO操作时能够创造并发操作。缺点:抢占资源,线程也不是越多越好,具体案例具体分析,请求上下文切换耗时。

进程和线程目的:提高执行效率。

在计算机中执行任务的最小单元是线程。Io操作不利用cpu,IO密集型需要多线程,计算密集型需要用多进程

GIL 全局解释器锁

  1. import threading
  2. import time
  3. def func1():
  4. print('')
  5. def func2(a1,a2):
  6. time.sleep(1)
  7. func1()
  8. print('a1+a2=%d'%(a1+a2))
  9. t1=threading.Thread(target=func2,args=(123,111,))#args传入的是一个元组,创建的是一个子线程
  10. #子线程是由主线程创建的,这个程序从上开始执行,当遇到这行代码时,会创建一个子线程
  11. t1.setDaemon(True)#设置主线程执行完之后等不等待子线程,默认是等待,改成True后将不等待,如果不等待,主线程将会
  12. #执行完创建下面三个子线程后就执行完了,并不会等待子线程去执行func2函数
  13. t1.start()#让创建的线程开始执行
  14. #t1.join()#让这个线程不再并发执行,会等到这个线程执行完毕,再执行下面的内容,当传入参数时,会表示最多等几秒
  15. t1.join(2) #下面的代码最多等这个线程2秒,如果没有执行完成,也会继续执行下面的内容,如果这个线程如果没有执行完,会再后台继续执行,但不会等着他
  16. t2=threading.Thread(target=func2,args=(123,111,))#args传入的是一个元组,创建的是一个子线程
  17. t2.start()#让创建的线程开始执行
  18. t3=threading.Thread(target=func2,args=(123,111,))#args传入的是一个元组,创建的是一个子线程
  19. t3.start()#让创建的线程开始执行

线程锁

python内部没有提供线程池,需要自定义   数据共享 m=Manger() dic=m.dict(),进程池python已经提供

上下文管理

  1. #with open (xx) as ss 原理是用上下文管理来实现的。
  2. import contextlib
  3. @contextlib.contextmanager#用于上下文管理
  4. def myopen(file_path,mode):
  5. f=open(file_path,mode,encoding='utf-8')
  6. try:
  7. yield f#执行到这一步会把f拿出来 赋给as后面的对象
  8. finally:
  9. f.close()
  10.  
  11. with myopen('XXX.txt','r') as file_obj:
  12. print(file_obj.readline())#执行任务,等所有的任务执行完成时,才执行finally后面的内容

css

1.首先找到那个标签,2.对那个标签进行操作

python 全栈开发笔记 4的更多相关文章

  1. python全栈开发笔记---------函数

    一 数学定义的函数与python中的函数 初中数学函数定义:一般的,在一个变化过程中,如果有两个变量x和y,并且对于x的每一个确定的值,y都有唯一确定的值与其对应,那么我们就把x称为自变量,把y称为因 ...

  2. python 全栈开发笔记 2

    函数 函数式:将某功能代码封装到函数中,日后便无需重复编写,仅调用函数即可 面向对象:对函数进行分类和封装,让开发“更快更好更强...” 函数式编程最重要的是增强代码的重用性和可读性 def xx() ...

  3. python全栈开发笔记---数据类型--综合练习题

    一.有两个列表 l1 = [11,22,33]       l2 = [22,33,44] a. 获取内容相同的元素列表 for item in l1: if item in l2: print(it ...

  4. python全栈开发笔记-----------概要

    Python开发 开发: 开发语言: 高级语言:python.Java.php  .C#   .Go .ruby . C++ .... ===>字节码 低级语言:C.汇编            ...

  5. python 全栈开发笔记 3

    正则表达式 正则表达式(RE)是一种小型的,高度专业化的,它镶嵌在python中,并通过re模块实现,正则表达式编译成一系列的字节码,然后由用c编写的匹配引擎执行. #正则表达式 import re ...

  6. python 全栈开发笔记 1

    将自己的姓名用进制表示出来 #自己姓名的进制表示 name=input('请输入你的名字:') for i in name: print(i) # python 3 中是按字符进行循环的 bytes_ ...

  7. python全栈开发笔记---------字符串格式化

    字符串格式化 %s 可以接收任何值, %d只能接收整形 .其他类型报错 msg ='i am %s my body' %'ales' print(msg) #i am ales my body msg ...

  8. python全栈开发笔记---------数据类型---字典方法

    def clear(self) 清空字典里所有元素 # info = { # "k1":18, # "k2":True, # "k3":[ ...

  9. python全栈开发笔记---------数据类型-----字典dict

    字典 #dict #1.基本结构 info= { "k1" : "v1", #键值对 "k2" : "v2" } ### ...

随机推荐

  1. jQuery Validate和Thymeleaf相关

    jQuery Validate https://www.cnblogs.com/liuhongfeng/p/5135676.html https://www.cnblogs.com/linjiqin/ ...

  2. 數據監控与診斷--環形緩沖區(RING BUFFER)

    1.  環形緩沖區 動態管理視圖: sys.dm_os_ring_buffers 查看ring_buffers: Select distinct ring_buffer_type from sys.d ...

  3. Python单元测试框架unittest

    学习接口自动化测试时接触了unittest单元测试框架,学习时参照了虫师编写的<selenium2自动化测试实战>,个人觉得里面讲的例子还比较容易理解的. 一.基础 1.main()和框架 ...

  4. C#操作Control异步工具类

    /// <summary> /// 异步工具类 /// </summary> public class TaskTools { /// <summary> /// ...

  5. openssl 生成pfx

    证书可以通过几种渠道获得, 可以购买, 可以使用IIS生成, 也可以使用Openssl这样的工具生成证书. 本篇文章主要介绍openssl生成pfx文件 首选去网关下载openssl 下载地址:htt ...

  6. HOMER | MEME | 转录因子的靶基因预测

    Finding Enriched Motifs in Genomic Regions (findMotifsGenome.pl) 在指定区域做motif enrichment,大大降低了假阳性. ME ...

  7. ajax得到后端数据一直提示为[object Object]解决方法

    前段ajax <script type="text/javascript"> function requestJson() { $.ajax({ type : &quo ...

  8. HTML CSS 特殊字符表

    HTML有许多特殊的字符,您对此有多少了解?平时在WEB制作中,您又有用到多少?或者说你在平时使用之时,是否也会碰到,有许多特殊字符要如何打印出来?比如说“笑脸”,比如说“版权号”.要是你用时忘记了这 ...

  9. 点击回到顶部(jQuery)

    写这个点击回到顶部.我采用的是最简单的jQuery,的点击事件  和animate特效. html部分 <div class="pulltop"> <img sr ...

  10. 瀑布流布局(等宽不等高jQuery)

    在百度上看见的好多都是引用Masonry插件   ,之后我自己尝试了一个没有使用插件的 <body> <div id="main"> <div cla ...