python-天池- part1-02

位运算

1. 原码、反码和补码

二进制的三种表示形式,计算机内部使用补码表示。

  • 原码:有一位符号位

    00 00 00 11 -> 3
    10 00 00 11 -> -3
    
  • 反码:正数的反码是原码,复数的反码是符号位不变,其余位取反

    00 00 00 11 -> 3
    11 11 11 00 -> -3
    
  • 补码:正数的补码就是原码,负数的补码就是反码+1

    00 00 00 11 -> 3
    11 11 11 01 -> -3
    

    符号位:最高位为符号位,0表示正数,1表示负数。在位运算中符号位也参与运算。

2. 按位运算

  • 按位非~

    把二进制数的0和1全部取反,包括符号位

  • 按位与&

    只有两个都为1时才为1

  • 按位或|

    只要其中一个为1就为1

  • 按位异或^

    对应位不同时为1

  • 按位左移

    将数值的二进制表示向左移动i位

  • 按位右移

    将数值的二进制表示向右移动i位

3. 位运算实现快速计算

  • 通过“>>”和“<<”可以实现快速计算2的倍数

  • 通过“^”可以快速交换两个数

  • 通过a&(-a)可以快速获取a的最后为1位置的整数

    print(8>>3) # 1
    
    a = 2 
    b = 5
    a ^= b
    b ^= a
    a ^= b
    print(a) # 5
    print(b) # 2
    
    print(a&(-a))
    

4. 位运算实现整数集合

一个数的二进制表示可以看做一个集合(0/1分别表示不在/在集合中)。

eg:集合{1, 3, 4, 8},可以表示成 01 00 01 10 10 而对应的位运算可就可以看作对集合进行的操作。

元素与集合的操作:

# a | (1<<i)  -> 把 i 插入到集合中
# a & ~(1<<i) -> 把 i 从集合中删除
# a & (1<<i)  -> 判断 i 是否属于该集合(零不属于,非零属于)
a = 4
print(bin(a)) #0b100
print(bin(a|(1<<7))) # 0b10000100
print(bin(a&~(1<<2))) # 0b0
print(bin(a&(1<<1))) # 0b0

集合之间的操作:

# a 补   -> ~a
# a 交 b -> a & b
# a 并 b -> a | b
# a 差 b -> a & (~b)

a = 4
b = 19
print(bin(a)) # 0b100
print(bin(b)) # 0b10011
print(bin(~a)) # -0b101
print(bin(a&b)) # 0b0
print(bin(a|b)) # 0b10111
print(bin(a&(~b))) # 0b100

整数在内存中是以补码的形式存在的,输出自然也是按照补码输出。

注意:

  • python中bin一个负数,是原码的二进制加上一个负号
  • python中整型是不限制程度的,不会超范围溢出,普通32位,超过会自动当长整型处理,几乎没有限制

流程控制

条件语句
  1. if语句

    # if expression:
    #     expr_true_suite
    
    if 2 > 1 and not 2 > 3:
        print('Correct Judgement!')
    # Correct Judgement!
    

    expression为真才执行expr_true_suite

  2. if - else语句

    # if expression:
    #     expr_true_suite
    # else:
    #     expr_false_suite
    
  3. if - elif - else语句

    if expression1:
        expr1_true_suite
    elif expression2:
        expr2_true_suite
        ·
        ·
    elif expressionN:
        exprN_true_suite
    else:
        expr_false_suite
    
  4. assert关键词

    assert这个关键词我们称之为“断言”,当这个关键词后边的条件为 False 时,程序自动崩溃并抛出AssertionError的异常。

    my_list = ['lsgogroup']
    my_list.pop(0)
    assert len(my_list) > 0
    
    # AssertionError
    
循环语句
  1. while循环

    while 布尔表达式:
        代码块
    
  2. while - else循环

    while 布尔表达式:
        代码块
    else:
        代码块
    

    while循环正常执行完的情况下,执行else输出,如果while循环中执行了跳出循环的语句,比如 break,将不执行else代码块的内容。

  3. for循环

    for 迭代变量 in 可迭代对象:
        代码块
    
  4. for - else循环

    for 迭代变量 in 可迭代对象:
        代码块
    else:
        代码块
    

    while - else类似

  5. range函数

    # range([start,] stop[, step=1])
    
    for i in range(2, 9):  # 不包含9
        print(i)
    
    # 2
    # 3
    # 4
    # 5
    # 6
    # 7
    # 8
    
  6. enumerate()函数

    enumerate(sequence, [start=0])
    
    • sequence:一个序列、迭代器或其他支持迭代对象。
    • start:下标起始位置。
    • 返回 enumerate(枚举) 对象
    seasons = ['Spring', 'Summer', 'Fall', 'Winter']
    lst = list(enumerate(seasons))
    print(lst)
    # [(0, 'Spring'), (1, 'Summer'), (2, 'Fall'), (3, 'Winter')]
    lst = list(enumerate(seasons, start=1))  # 下标从 1 开始
    print(lst)
    # [(1, 'Spring'), (2, 'Summer'), (3, 'Fall'), (4, 'Winter')]p
    
  7. break语句

    可以跳出当前所在层的循环

  8. continue语句

    提前终止本轮循环,进入下一轮

  9. pass语句

    pass 语句的意思是“不做任何事”,如果你在需要有语句的地方不写任何语句,那么解释器会提示出错,而 pass 语句就是用来解决这些问题的。

推导式
  1. 列表推导式

    # [ expr for value in collection [if condition] ]
    
    x = [(i, i ** 2) for i in range(100) if (i % 2) != 0 and (i % 3) == 0]
    print(x)
    
    # [(3, 9), (9, 81), (15, 225), (21, 441), (27, 729), (33, 1089), (39, 1521), (45, 2025), (51, 2601), (57, 3249), (63, 3969), (69, 4761), (75, 5625), (81, 6561), (87, 7569), (93, 8649), (99, 9801)]
    
  2. 元组推导式

    # ( expr for value in collection [if condition] )
    
    a = (x for x in range(10))
    print(a)
    # <generator object <genexpr> at 0x0000025BE511CC48>
    
    print(tuple(a))
    # (0, 1, 2, 3, 4, 5, 6, 7, 8, 9)
    
  3. 字典推导式

    # { key_expr: value_expr for value in collection [if condition] }
    
    b = {i: i % 2 == 0 for i in range(10) if i % 3 == 0}
    print(b)
    # {0: True, 3: False, 6: True, 9: False}
    
  4. 集合推导式

    # { expr for value in collection [if condition] }
    
    c = {i for i in [1, 2, 3, 4, 5, 5, 6, 4, 3, 2, 1]}
    print(c)
    # {1, 2, 3, 4, 5, 6}
    

异常处理

  1. Python 标准异常总结

    • BaseException:所有异常的 基类
    • Exception:常规异常的 基类
    • StandardError:所有的内建标准异常的基类
    • ArithmeticError:所有数值计算异常的基类
    • FloatingPointError:浮点计算异常
    • OverflowError:数值运算超出最大限制
    • ZeroDivisionError:除数为零
    • AssertionError:断言语句(assert)失败
    • AttributeError:尝试访问未知的对象属性
    • EOFError:没有内建输入,到达EOF标记
    • EnvironmentError:操作系统异常的基类
    • IOError:输入/输出操作失败
    • OSError:操作系统产生的异常(例如打开一个不存在的文件)
    • WindowsError:系统调用失败
    • ImportError:导入模块失败的时候
    • KeyboardInterrupt:用户中断执行
    • LookupError:无效数据查询的基类
    • IndexError:索引超出序列的范围
    • KeyError:字典中查找一个不存在的关键字
    • MemoryError:内存溢出(可通过删除对象释放内存)
    • NameError:尝试访问一个不存在的变量
    • UnboundLocalError:访问未初始化的本地变量
    • ReferenceError:弱引用试图访问已经垃圾回收了的对象
    • RuntimeError:一般的运行时异常
    • NotImplementedError:尚未实现的方法
    • SyntaxError:语法错误导致的异常
    • IndentationError:缩进错误导致的异常
    • TabError:Tab和空格混用
    • SystemError:一般的解释器系统异常
    • TypeError:不同类型间的无效操作
    • ValueError:传入无效的参数
    • UnicodeError:Unicode相关的异常
    • UnicodeDecodeError:Unicode解码时的异常
    • UnicodeEncodeError:Unicode编码错误导致的异常
    • UnicodeTranslateError:Unicode转换错误导致的异常
  2. python标准警告总结

    • Warning:警告的基类
    • DeprecationWarning:关于被弃用的特征的警告
    • FutureWarning:关于构造将来语义会有改变的警告
    • UserWarning:用户代码生成的警告
    • PendingDeprecationWarning:关于特性将会被废弃的警告
    • RuntimeWarning:可疑的运行时行为(runtime behavior)的警告
    • SyntaxWarning:可疑语法的警告
    • ImportWarning:用于在导入模块过程中触发的警告
    • UnicodeWarning:与Unicode相关的警告
    • BytesWarning:与字节或字节码相关的警告
    • ResourceWarning:与资源使用相关的警告
  3. try - except语句

    try:
        检测范围
    except Exception[as reason]:
        出现异常后的处理代码
    

    try 语句按照如下方式工作:

    • 首先,执行try子句(在关键字try和关键字except之间的语句)
    • 如果没有异常发生,忽略except子句,try子句执行后结束。
    • 如果在执行try子句的过程中发生了异常,那么try子句余下的部分将被忽略。如果异常的类型和except之后的名称相符,那么对应的except子句将被执行。最后执行try - except语句之后的代码。
    • 如果一个异常没有与任何的except匹配,那么这个异常将会传递给上层的try中。
  4. try - except - finally语句

    try: 检测范围 except Exceptionas reason: 出现异常后的处理代码 finally: 无论如何都会被执行的代码

    不管try子句里面有没有发生异常,finally子句都会执行。

  5. try - except - else语句

    如果在try子句执行时没有发生异常,Python将执行else语句后的语句。

    try:
        检测范围
    except:
        出现异常后的处理代码
    else:
        如果没有异常执行这块代码
    
  6. raise语句

    Python 使用raise语句抛出一个指定的异常。

    try:
        raise NameError('HiThere')
    except NameError:
        print('An exception flew by!')
        
    # An exception flew by!
    
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Python爬虫笔记,python基础知识,以TXT文件呈现 一、概述 Python是著名的“龟叔”Guido van Rossum在1989年圣诞节期间,为了打发无聊的圣诞节而编写的一个编程语言。 Python为我们提供了非常完善的基础代码库,覆盖了网络、文件、GUI、数据库、文本等大量内容,被形象地称作“内置电池(batteries included)”。用Python开发,许多功能不必从零编写,直接使用现成的即可。 龟叔给Python的定位是“优雅”、“明确”、“简单”,所以Python程序看上去总是简单易懂,初学者学Python,不但入门容易,而且将来深入下去,可以编写那些非常非常复杂的程序。 那Python适合开发哪些类型的应用呢? 首选是网络应用,包括网站、后台服务等等; - PythonWeb 其次是许多日常需要的小工具,包括系统管理员需要的脚本任务等等; - Python 另外就是把其他语言开发的程序再包装起来,方便使用。 - 胶水语言 在 爬虫 科学计算 等领域有独特优势 AI Python的优点 简单易学 完善的语言特性 天然开源 丰富的社区支持 Python的缺点。 第一个缺点就是运行速度慢,和C程序相比非常慢,因为Python是解释型语言,你的代码在执行时会一行一行地翻译成CPU能理解的机器码,这个翻译过程非常耗时,所以很慢。而C程序是运行前直接编译成CPU能执行的机器码,所以非常快。 但是大量的应用程序不需要这么快的运行速度,因为用户根本感觉不出来。例如开发一个下载MP3的网络应用程序,C程序的运行时间需要0.001秒,而Python程序的运行时间需要0.1秒,慢了100倍,但由于网络更慢,需要等待1秒,你想,用户能感觉到1.001秒和1.1秒的区别吗?这就好比F1赛车和普通的出租车在北京三环路上行驶的道理一样,虽然F1赛车理论时速高达400公里,但由于三环路堵车的时速只有20公里,因此,作为乘客,你感觉的时速永远是20公里。 第二个缺点就是代码不能加密。如果要发布你的Python程序,实际上就是发布源代码,这一点跟C语言不同,C语言不用发布源代码,只需要把编译后的机器码(也就是你在Windows上常见的xxx.exe文件)发布出去。要从机器码反推出C代码是不可能的,所以,凡是编译型的语言,都没有这个问题,而解释型的语言,则必须把源码发布出去。 二、安装配置 安装包下载地址: http://www.python.org/download/ Python目前分为两大版本,互不兼容: 2.x.x 3.x.x 下载的时候要注意区分 根据需要的版本进行下载 目前两者都有所使用 双击安装 设置环境变量: 将python安装位置配置到PATH环境变量下。 三、运行方式 shell方式: 在cmd窗口中输入python进入命令行模式 在其中以交互式方式执行 shell方式调用py文件: 在文件中编写Python脚本 文件后缀为.py 进入该文件所在目录 直接执行./xxx.py IDE模式: pycharm pyDev for Eclipse **Python编码 Python默认读取py文件时采用的编码格式是 ASCII 格式,如果文件不是该格式很可能出现乱码问题造成异常。 解决方法为只要在文件开头加入 # -*- coding: UTF-8 -*- 或者 #coding=utf-8 来通知Python解释器在读取文件时采用的编码集 四、标识符 在 Python 中,所有标识符可以包括英文、数字以及下划线(_),但不能以数字开头。 Python 中的标识符是区分大小写的。 以下划线开头的标识符是有特殊意义的。 以单下划线开头 _foo 的代表不能直接访问的类属性,需通过类提供的接口进行访问,不能用 from xxx import * 而导入; 以双下划线开头的 __foo 代表类的私有成员;以双下划线开头和结尾的 __foo__ 代表 Python 里特殊方法专用的标识,如 __init__() 代表类的构造函数。 五、语言细节 1.语句 Python通常一行为一条语句 不需要分号标识 Python 可以同一行显示多条语句,方法是用分号 ; 案例: print 'hello';print 'runoob'; 也可以使用反斜杠将一行语句分为多行解释: 案例: total = item_one + \.....................................................

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值