Collection record

复习大集合:

1.函数的参数:位置参数,关键字参数,动态参数

2.命名空间:内置命名空间,全局命名空间,局部命名空间

3.闭包函数:函数引用未定义的函数外非全局的变量叫做闭包,该函数称为闭包函数

4.函数无返回值:1.不写 2.return 3.return None 无返回值None

5.函数返回值个数:多个返回值可以用一个变量接收,并存成元组方式,或者用多个变量接收,可以直接返回一个列表或者一个元组

6.字符编码:unicode 万国码(所有字符用两个字节接受,转换速度快,但是占内存) utf8 英文编码一个字节,中文两个字节

7.执行python两种方式:1 ./Python.py 行首要指定解释语言 2python python.py 直接指定使用python 解释

8.pyc,编译后的跨平台字节码文件,由Python虚拟机来执行,提高加载的速度

9.n.bin_length() 返回二进制的长度

10.68个内置函数

11.globals() 获取全局变量的字典,locals() 获取本地方法所在命名空间的局部变量的字典,只读

12.hash(0)返回变量的哈希值,元组可以哈希,列表不可以哈希

13.eval 执行字符串形式的计算表达式,exec 执行字符串形式的Python语句

14.filter(func,list);将list中的元素遍历做func的规则,返回一个新列表

15.map(func,list);将list中的元素遍历做func的运算后,返回一个新列表

16.数字转换:bin,oct,hex

17.数字运算:abs,divmod,min,max,sum,round,pow

18.迭代器: iter_1 = [1,2,3,4].__inter__() 获取一个迭代器对象

            iter_1.__length_hint__(),获取迭代器中元素长度

            iter_1.__setatate__(4),从索引位置开始迭代

            iter_1.next(),一个一个获取迭代元素

19.生成器

    def genrator_func():

        a=1

        yield a  使用yield一个一个存储

        b=2

        yield b

       

    g1=genrator_func()

    next(g1) == a

    next(g1) == b  使用next一个一个获取

 eg:

    def h():

        print 'start yield'

        m = yield 5

        print m                            #n=yield r

        d = yield 12                       #r=c.send(n)

       

        c = h()

        print(c.next())

        print(c.send('sss'))

    send方法就是向函数中传值,把值赋给yield对应的变量,同时还执行next方法

        >>5

        >>sss

        >>12

       

20.要用一个send方法的生成器一定至少要含有两个yield

21.yeild from :

    def func():

        yeild from [1,2,3]  #循环yeild

 

22.range 和 xrange 的区别,xrange 不返回list,而是返回一个iterable的对象,避免承包缓存

23.[i for i in range(10) if i%2==0] :获取0-10之间的偶数

24.list(map(lambda z:{z[0]:z[1]},zip(t1,t2)))

25.正则匹配 后面加一个(?)使其变成惰性匹配 ,Python默认是贪婪匹配(即尽可能多的匹配)

26.正则匹配 字符串前面加 r 表示不匹配。

27.正则匹配 .*?X 前面取任意长度,知道遇到X

    re.compile() 匹配规则 obj=re.compile() ret=obj.findall()

    re.findall() 匹配所有

    re.search() 匹配一个则返回,通过.group()方法获取匹配的字符串,没有匹配返回None

    re.match() 从字符串开始处匹配,其他同re.search()

    re.split('[ab]','abgsefs') 先按a分割,在按b进行分割,结果返回列表

    re.split('(2)','sdf2sdf') ['sdf','2','sdf'],split的优先级,保留匹配的部分

    re.sub('\d','-','ssf2sf3',1) 将数字替换成‘-’指定替换一次,,默认是全替换

    re.subn('\d','-','sdfa2sdf6a') 将数字全替换成‘-’,放回一个元组('sdfa-sdf-a',2)

    re.finditer('\d', 'sdfaqef2asd45f') 返回一个迭代器: next(ret).group() 获取一个值

    re.search(r'(?P<name>go)\s+(?P=name)\s+(?P=name)', 'go go go').group('name') 命名分组

28.collections 内置模块

    namedtuple:

    deque:实现高效插入和删除的双向列表,适用于队列和栈

    defaultdict:使用dict时,如果引用的KEY不存在时,就好抛异常,使用defaultdict可以返回一个默认值

    OrderedDict: dict是无序的,如果要保存key的顺序可以使用OrderedDict

    Counter, 计算出现的次数

29.json.dump(dict,f) #接受一个文件句柄,直接将字典换成字符串写入文件

   json.load(f) #接受一个文件句柄,直接将文件中的json字符串转换成数据结构返回

30.json 用于字符串和Python数据类型间进行转换

   pickle 用于Python特有的类型 和Python的数据类型进行转换

31.子类引用父类的方法,super(B,b).hahah() 即使子类有hahah()方法也直接使用父类的方法

32.子类构造方法中,引用父类的构造方法,两种方式:

    Baseclass.__init__(a,b,c) ,Teacher.__init__(self,name,gender)

    super().__init__(name, aggressivity, life_value)

    super(B,self).__init__()

33.python interface: abc 模块 父类的方法加上装饰器后,子类继承必须重写父类被装饰的方法,否则活报错。

34.避免多继承,推荐多实现接口,(大量的多继承,会出现不需要的属性被继承到,造成资源浪费)

35.访问私有属性,bar._Bar__city ,外部访问父类的私有方法,obj._父类名__属性

36.父类的私有方法不会被子类覆盖,

37.isinstance(obj,Foo) 判断obj 是否Foo的子类;issubclass(Bar,Foo) 判断Bar是否Foo的子类

38.但是当你用字符串格式化的时候 %s和%r会分别去调用__str__和__repr__

39.struct该模块可以把一个类型,如数字,转成固定长度的bytes ,解决粘包的时候可以使用,让对方先接收固定长度的bytes,解读出信息头和信息长度。

40.CSS中不被继续的属性:border, margin, padding

41.比较运算符两侧如果一个是数字类型,一个是其他类型,会将其类型转换成数字类型.

42.比较运算符两侧如果都是字符串类型,比较的是最高位的asc码,如果最高位相等,继续取第二位比较

43.其他:

    如果一个运算数是 Boolean 值,在检查相等性之前,把它转换成数字值。false 转换成 0,true 为 1。

    如果一个运算数是字符串,另一个是数字,在检查相等性之前,要尝试把字符串转换成数字。

    如果一个运算数是对象,另一个是字符串,在检查相等性之前,要尝试把对象转换成字符串。

    如果一个运算数是对象,另一个是数字,在检查相等性之前,要尝试把对象转换成数字。

44.var x= (new Date()).getDay(); 获取今天的星期值,0位星期天

45.JavaScript中的JSON:1.JSON.parse() 将JSON字符串转换为JavaScript对象 2.JSON.stringify()将对象转换为字符串

46.csrfmiddlewaretoken:$("[name='csrfmiddlewaretoken']").val(),csrf 会自动加一个class='hide'的input 标签

47.Ajax对于csrf的四种方式:1.data: {csrfmiddlewaretoken: '{{ csrf_token }}' }, 4.@csrf_exempt

                   2.{% csrf_token %}  3.headers:{"X-CSRFToken":$.cookie('csrftoken')},

48.Ajax 异步,局部刷新

49.Ajax 原理流程

    1.打开与服务器的连接(xmlHttp.open('GET','ajax_get/?a=1'),true) async:默认为True,表示异步请求

    2.发送请求 (xmlHttp.send(null))

    3.接收服务器响应 xmlHttp.onreadystatechange = function() {

                        if(xmlHttp.readyState == 4 && xmlHttp.status == 200) {

                            alert(xmlHttp.responseText);   

                        }};

50.表单序列化:data: $("#fm").serialize(),获取form表单中有name属性的控件值,带有disabled的属性不提交,返回String类型

51.文件上传:<p>密码: <input type="password" name="pwd"></p>

    fileobj=request.FILES.get("file")

        with open(fileobj.name,"wb")as f:

            for line in fileobj:

                f.write(line)

51.flask:login的装饰器函数必须在路由函数的下面,紧贴着函数

52.WTForms是一个支持多个web框架的form组件,主要用于对用户请求数据进行验证。

    .name=simple.StringField()

    .email=html5.EmailField()

    .gender=core.RadioField()

53.type("ReedSun", (ShuaiGe,), {"shuai":True, "test":lambda x: x+2}) 通过type创建一个类

54.partial(_lookup_req_object, 'session') #偏函数

55.sqlAlchemy:中操作数据库是session和scoped_session的区别:

    由于无法提供线程共享功能,所以在开发时要注意给每一个线程创建自己的session

    scoped_session封装的两个值,session 和 registry,registry()执行ThreadLocalRegistry的__call__方法,如果

    当前本地线程中有session 就返回session,没有就将session添加到本地线程

    优点:支持线程安全,为每一个线程都创建一个session

    两种方式:通过本地线程Threading.Local()和创建线程的唯一标识实现

54.django的缓存,1.设置缓存:self.cache.set(self.key,) 2.获取缓存:self.cache.get(self.key, [])

55.接口的两种方式:1.不重写直接抛异常。2.

   from abc import abstractmethod, ABCMeta

   class Interface(metaclass=ABCMeta):

    @abstractmethod

    def method(self, arg): pass

56.算法:

    1.冒泡排序:比较两个相邻的数,如果前面比后面大就交换位置

    2.选择排序:遍历一次记录最小的数,放置在第一个位置,在遍历一次,放置在第二个位置

    3.插入排序:列表被分为有序区和无序区,最初有序区只有一个元素。每次从无序区选择一个元素,插入到有序区的位置,直到无序区变空。

57.flask的session默认将用户信息加密成字符串作为cookie传回给用户,缓存到数据库导入flask_session插件

58.with obj: 会自动执行__enter__ 函数体执行完 再自动执行__exti__

59.去除字符串中的换行使用s.replace(os.sep, '')

posted @ 2018-05-02 16:38  mihon  阅读(143)  评论(0编辑  收藏  举报