zoukankan      html  css  js  c++  java
  • python 小笔记

    NoSQL 是什么,优势在哪?

    NoSQL 全称为 Not Only SQL,传统 的关系模型使用 的是固定模式 , 并将数据分割到各个表中 。 然而 , 对于大数 据集的情况 , 数据量太大使其难 以 存放在单一服务器 中 , 此 时就需要扩展到 多 台服务器 。 不过 , 关系模型对于这种扩展的支持并不够好 , 因为在查询多 个表时 , 数据可能在不 同 的服务器中 。 相反 , NoSQL 数据库通常是无模式的 , 从设计之初就考虑 了跨服务器无缝分片的问题 。 在 NoSQL 中 , 有多种方式可 以 实现该 目标 , 分别是列数据存储 ( 如 HBase )、 键值对存储 ( 如 Redis ) 、 面 向 文档 的 数据库 ( 如 MongoDB ) 以及 图 形数据库( 如 Neo4j )。

    已知以下序列:

    list2=[{'mm':2},{'mm':2},{'mm':3},{'mm':1},{'mm':5},{'mm':4},{'mm':3}]

    1.按照list2中元素mm的值排序
    list1=sorted(list2,key=lambda list2: list2['mm'])

    print(list1) #[{'mm': 1}, {'mm': 2}, {'mm': 2}, {'mm': 3}, {'mm': 3}, {'mm': 4}, {'mm': 5}]
    2.获取第一个mm的值为4的元素
    for index,i in enumerate(list2):
    if i['mm'] == 4:
    print(index,i)
    break #5 {'mm':4}
    3.输出list2[::4]

    [{'mm': 2}, {'mm': 5}]
    4.删除list2中所有mm值等于2的元素,且不对list2重新赋值
    n=0
    while n<len(list2):
    if list2[n]['mm']==2:
    del list2[n]
    else:
    n+=1

    print(list2) #[{'mm': 3}, {'mm': 1}, {'mm': 5}, {'mm': 4}, {'mm': 3}]

    5.取出list2 中mm值最大的元素,不能排序
    ind = 0
    def get_max(n):
    for i in range(1,len(n)):
    global ind
    if list2[i]['mm'] > list2[ind]['mm']:
    ind = i
    return n[ind]
    print(get_max(list2)) #{'mm':5}
     

    解释一下以下情况出现的原因

    >>> '{:0.2f}'.format(3.135)

    '3.13'

    >>> '{:0.2f}'.format(3.145)

    '3.15'

    计算机浮点数的误差,涉及知识点:Fixed Point 定点数表示法

    这两个数的定点数表示法

    3.145:3.1450000000000000177635683940

    3.135:3.1349999999999997868371792719699442386627197265625

    所以就是一个简单的四舍五入:3.1349显然舍了4,3.1450显然入了5

    简述GIL:

    python全局解释器锁。解决多线程之间数据完整性和状态同步的最简单方法自然就是加锁, 于是有了GIL这把超级大锁。cpython解析只允许拥有GIL全局解析器锁才能运行程序,保证同一个时刻只允许一个线程可以使用cpu。

    简述代码抛出异常的原因:

    IndexError :序列中没有此索引(index)

    AttributeError:对象没有这个属性。

    AssertionError :断言语句失败。

    NotImplementedError:尚未实现的方法。

    StopIteration:迭代器没有更多的值

    TypeError:对类型无效的操作

    IdentationError:缩进错误

    cookie 和session 的区别与联系:

    1、cookie数据存放在客户的浏览器上,session数据放在服务器上。

    2、cookie不是很安全,别人可以分析存放在本地的COOKIE并进行COOKIE欺骗
       考虑到安全应当使用session。

    3、session会在一定时间内保存在服务器上。当访问增多,会比较占用你服务器的性能
       考虑到减轻服务器性能方面,应当使用COOKIE。

    4、单个cookie保存的数据不能超过4K,很多浏览器都限制一个站点最多保存20个cookie。

    Cookies是属于Session对象的一种。但有不同,Cookies不会占服务器资源,是存在客服端内存或者一个cookie的文本文件中;而“Session”则会占用服务器资源

     python中的魔法方法

    python中以两个下划线__包围的都有特殊的意思,其中是方法的都是魔法方法。

    python中的魔法方法魔法的地方就是你不需要显示的调用,就可以实现自动调用。其实每个魔法方法都是在对内建方法的重写,和做像装饰器一样的行为

      最常用的魔术方法,

      __init__(self[,...])      __init__ ,通过此方法我们可以定义一个对象的初始操作。__new__(cls[,...])     __new__是在一个对象实例化时候所调用的第一个方法,第一个参数是这个类,其他的参数是用来直接传递给__init__方法,__new__决定是否使用该 __init__方法。

    魔法方法
    含义
     
    基本的魔法方法
    __new__(cls[, ...]) 1. __new__ 是在一个对象实例化的时候所调用的第一个方法
    2. 它的第一个参数是这个类,其他的参数是用来直接传递给 __init__ 方法
    3. __new__ 决定是否要使用该 __init__ 方法,因为 __new__ 可以调用其他类的构造方法或者直接返回别的实例对象来作为本类的实例,如果 __new__ 没有返回实例对象,则 __init__ 不会被调用
    4. __new__ 主要是用于继承一个不可变的类型比如一个 tuple 或者 string
    __init__(self[, ...]) 构造器,当一个实例被创建的时候调用的初始化方法
    __del__(self) 析构器,当一个实例被销毁的时候调用的方法
    __call__(self[, args...]) 允许一个类的实例像函数一样被调用:x(a, b) 调用 x.__call__(a, b)
    __len__(self) 定义当被 len() 调用时的行为
    __repr__(self) 定义当被 repr() 调用时的行为
    __str__(self) 定义当被 str() 调用时的行为
    __bytes__(self) 定义当被 bytes() 调用时的行为
    __hash__(self) 定义当被 hash() 调用时的行为
    __bool__(self) 定义当被 bool() 调用时的行为,应该返回 True 或 False
    __format__(self, format_spec) 定义当被 format() 调用时的行为
      有关属性
    __getattr__(self, name) 定义当用户试图获取一个不存在的属性时的行为
    __getattribute__(self, name) 定义当该类的属性被访问时的行为
    __setattr__(self, name, value) 定义当一个属性被设置时的行为
    __delattr__(self, name) 定义当一个属性被删除时的行为
    __dir__(self) 定义当 dir() 被调用时的行为
    __get__(self, instance, owner) 定义当描述符的值被取得时的行为
    __set__(self, instance, value) 定义当描述符的值被改变时的行为
    __delete__(self, instance) 定义当描述符的值被删除时的行为
      比较操作符
    __lt__(self, other) 定义小于号的行为:x < y 调用 x.__lt__(y)
    __le__(self, other) 定义小于等于号的行为:x <= y 调用 x.__le__(y)
    __eq__(self, other) 定义等于号的行为:x == y 调用 x.__eq__(y)
    __ne__(self, other) 定义不等号的行为:x != y 调用 x.__ne__(y)
    __gt__(self, other) 定义大于号的行为:x > y 调用 x.__gt__(y)
    __ge__(self, other) 定义大于等于号的行为:x >= y 调用 x.__ge__(y)
      算数运算符
    __add__(self, other) 定义加法的行为:+
    __sub__(self, other) 定义减法的行为:-
    __mul__(self, other) 定义乘法的行为:*
    __truediv__(self, other) 定义真除法的行为:/
    __floordiv__(self, other) 定义整数除法的行为://
    __mod__(self, other) 定义取模算法的行为:%
    __divmod__(self, other) 定义当被 divmod() 调用时的行为
    __pow__(self, other[, modulo]) 定义当被 power() 调用或 ** 运算时的行为
    __lshift__(self, other) 定义按位左移位的行为:<<
    __rshift__(self, other) 定义按位右移位的行为:>>
    __and__(self, other) 定义按位与操作的行为:&
    __xor__(self, other) 定义按位异或操作的行为:^
    __or__(self, other) 定义按位或操作的行为:|
      反运算
    __radd__(self, other) (与上方相同,当左操作数不支持相应的操作时被调用)
    __rsub__(self, other) (与上方相同,当左操作数不支持相应的操作时被调用)
    __rmul__(self, other) (与上方相同,当左操作数不支持相应的操作时被调用)
    __rtruediv__(self, other) (与上方相同,当左操作数不支持相应的操作时被调用)
    __rfloordiv__(self, other) (与上方相同,当左操作数不支持相应的操作时被调用)
    __rmod__(self, other) (与上方相同,当左操作数不支持相应的操作时被调用)
    __rdivmod__(self, other) (与上方相同,当左操作数不支持相应的操作时被调用)
    __rpow__(self, other) (与上方相同,当左操作数不支持相应的操作时被调用)
    __rlshift__(self, other) (与上方相同,当左操作数不支持相应的操作时被调用)
    __rrshift__(self, other) (与上方相同,当左操作数不支持相应的操作时被调用)
    __rxor__(self, other) (与上方相同,当左操作数不支持相应的操作时被调用)
    __ror__(self, other) (与上方相同,当左操作数不支持相应的操作时被调用)
      增量赋值运算
    __iadd__(self, other) 定义赋值加法的行为:+=
    __isub__(self, other) 定义赋值减法的行为:-=
    __imul__(self, other) 定义赋值乘法的行为:*=
    __itruediv__(self, other) 定义赋值真除法的行为:/=
    __ifloordiv__(self, other) 定义赋值整数除法的行为://=
    __imod__(self, other) 定义赋值取模算法的行为:%=
    __ipow__(self, other[, modulo]) 定义赋值幂运算的行为:**=
    __ilshift__(self, other) 定义赋值按位左移位的行为:<<=
    __irshift__(self, other) 定义赋值按位右移位的行为:>>=
    __iand__(self, other) 定义赋值按位与操作的行为:&=
    __ixor__(self, other) 定义赋值按位异或操作的行为:^=
    __ior__(self, other) 定义赋值按位或操作的行为:|=
      一元操作符
    __neg__(self) 定义正号的行为:+x
    __pos__(self) 定义负号的行为:-x
    __abs__(self) 定义当被 abs() 调用时的行为
    __invert__(self) 定义按位求反的行为:~x
      类型转换
    __complex__(self) 定义当被 complex() 调用时的行为(需要返回恰当的值)
    __int__(self) 定义当被 int() 调用时的行为(需要返回恰当的值)
    __float__(self) 定义当被 float() 调用时的行为(需要返回恰当的值)
    __round__(self[, n]) 定义当被 round() 调用时的行为(需要返回恰当的值)
    __index__(self) 1. 当对象是被应用在切片表达式中时,实现整形强制转换
    2. 如果你定义了一个可能在切片时用到的定制的数值型,你应该定义 __index__
    3. 如果 __index__ 被定义,则 __int__ 也需要被定义,且返回相同的值
      上下文管理(with 语句)
    __enter__(self) 1. 定义当使用 with 语句时的初始化行为
    2. __enter__ 的返回值被 with 语句的目标或者 as 后的名字绑定
    __exit__(self, exc_type, exc_value, traceback) 1. 定义当一个代码块被执行或者终止后上下文管理器应该做什么
    2. 一般被用来处理异常,清除工作或者做一些代码块执行完毕之后的日常工作
      容器类型
    __len__(self) 定义当被 len() 调用时的行为(返回容器中元素的个数)
    __getitem__(self, key) 定义获取容器中指定元素的行为,相当于 self[key]
    __setitem__(self, key, value) 定义设置容器中指定元素的行为,相当于 self[key] = value
    __delitem__(self, key) 定义删除容器中指定元素的行为,相当于 del self[key]
    __iter__(self) 定义当迭代容器中的元素的行为
    __reversed__(self) 定义当被 reversed() 调用时的行为
    __contains__(self, item) 定义当使用成员测试运算符(in 或 not in)时的行为
  • 相关阅读:
    数据库异常状态:Recovery Pending,Suspect,估计Recovery的剩余时间
    Windows:任务调度器
    Package设计2:增量更新
    SSIS 数据流优化
    Data Profiling Task
    SSIS 表达式、操作符和函数
    SSIS 数据流的错误输出
    SSIS 控制流和数据流
    SET QUOTED_IDENTIFIER选项对索引的影响
    Security2:角色和权限
  • 原文地址:https://www.cnblogs.com/master-song/p/8965626.html
Copyright © 2011-2022 走看看