Python-Day9

1. 知识回顾

  isinstance(object, class)   ---->   判断该对象是否是该类的实例

s = 'cnskcsk'

ret = isinstance(s, str)

print(ret)

#>>>>>>>>>>>>>>>
True

  

  传入 列表 字典 集合 时,默认传入的是实参的引用地址,即可以修改实参

def app(args):
    args.append('333')
    return args

li = [11,22]
ret = app(li)
print(li)

#>>>>>>>>>>>
[11, 22, '333']

  一旦对形参进行赋值操作,就新开辟一块内存使args指向这块新开辟的,而实参不变

def app(args):
    args = 'qweqweqwe'
    return args

li = [11,22]
ret = app(li)
print(li)

#>>>>>>>>>>>
[11, 22]

  

处理字典 列表等有两种方式:1改变自身  *2返回新建的变量*

# def qu2(args):
#     r = {}
#     for key, value in args.items():
#         if len(value) > 2:
#             r[key] = value[0:2]
#         else:
#             r[key] = value
#     return r
#
# l = {'k1': 'xascaasdx', 'k2': 'cf', 'k3': [11,22,33]}
# print(qu2(l))

>>>>>>>>>>>>>>>>>>>>>>>>>>两种方法

def qu2(args):
    for key, value in args.items():
        if len(value) > 2:
            args[key] = value[0:2]
        else:
            args[key] = value

l = {'k1': 'xascaasdx', 'k2': 'cf', 'k3': [11,22,33]}
qu2(l)
print(l)

  

2. lambda表达式

  简易的表示函数

def f1(a1, a2):
    return a1 + a2

f2 = lambda a1, a2: a1 + a2

r1 = f1(1, 2)
r2 = f2(1, 2)

print(r1)
print(r2)

#>>>>>>>>>
3
3

 

3. 内置函数

 

  0 None "" [] () {} 为False , 其他为True

  abs() 取绝对值

  all()   循环参数,若每个元素都为True, 返回真

  any() 循环参数,只要有一个True, 返回True

  ascii()  去参数对象的类中寻找 __repr__() 方法, 执行获取返回值

  bin()  二进制

  oct() 八进制

  int() 十进制      ret = int('0b1010', base=2)   ---->    将二进制转为十进制

  hex()  十六进制

  bool() 判断真假,即将参数转为布尔值

  bytes()        字节

  bytearray()  字节数组,每一个元素为字节, 类似 字符串跟列表的关系

  chr()  接收一个十进制数,返回对应ASCII码的字符

  ord()  与 chr() 相反,接收一个字符,返回ASCII对应十进制数

  小例子:生成随机验证码

import random

temp = ''
for i in range(4):
    num = random.randrange(65, 91) #65~90 A~Z
    ch = chr(num)
    temp += ch

print(temp)   #随机生成四位验证码

  改进为 既包含数字 又包含字母的

import random

temp = ''
for i in range(6):
    rd = random.randrange(0, 4)
    if rd == 1 or rd == 3:
        num1 = random.randrange(0, 10)
        temp += str(num1)
    else:
        num = random.randrange(65, 91)  # 65~90 A~Z
        ch = chr(num)
        temp += ch

print(temp)   #随机生成6位验证码

  

  callable()   检测参数是否是可执行的

  compile()   把字符串编译成可执行代码,可以与exec()结合使用

  dir() 返回对象所在类里的所有方法

  help() 输出类的所有详细信息

  divmod()   divmod(a, b)   返回a/b的 商 和 余数 组成的元组,可以用在 分页 中

  eval()  执行一个字符串格式的表达式

ret = eval('1 + 3 * 2')

print(ret)

#>>>>>>>>>>>

7

  后面可以带字典指定字符串中的变量值

ret = eval('a + 10', {'a':23})
#后面带字典,指定变量的值
print(ret)

#>>>>>>>>>>>
33

  exec()  执行字符串形式的代码,没有返回值  

exec('for i in range(10): print(i)')

#>>>>>>>>>
0
1
2
3
4
5
6
7
8
9

  filter()      filter(函数名, 可迭代的对象)  循环取后者的元素,作为函数的参数,执行。若返回True, 保存该元素

        即 过滤出符合条件的元素

def f1(args):
    if args > 22:
        return True
    else:
        return False

ret = filter(f1, [11, 22, 33, 44])

print(ret)

for i in ret:
    print(i)

#通过lambda表达式
ret = filter(lambda x: x > 22, [11, 22, 33, 44])

print(ret)

for i in ret:
    print(i)

#>>>>>>>>>>>

<filter object at 0x00000238C7A7CE48>
33
44
<filter object at 0x00000238C7A7CE80>
33
44

  map()   跟filter() 类似,不同在于 对每个元素做统一的处理

def f1(args):
    return args + 100

ret = map(f1, [11, 22, 33, 44])

print(ret)

for i in ret:
    print(i)

#通过lambda表达式
ret = map(lambda x: x + 100, [11, 22, 33, 44])

print(ret)

for i in ret:
    print(i)

#>>>>>>>>>>>
<map object at 0x000001BF2210CE48>
111
122
133
144
<map object at 0x000001BF2210CE80>
111
122
133
144

  

def f1(args):
    if args % 2 == 0:
        return args + 100
    else:
        return args

ret = map(f1, [11, 22, 33, 44])

print(ret)

for i in ret:
    print(i)

#通过lambda表达式
ret = map(lambda x: x + 100 if x % 2 == 0 else x, [11, 22, 33, 44])

print(ret)

for i in ret:
    print(i)

#>>>>>>>>>>>

<map object at 0x000001FF537FCE48>
11
122
33
144
<map object at 0x000001FF537FCE80>
11
122
33
144

  locals()  获取所有局部变量

  globals()   获取所有全局变量

def f1():
    n1 = 123
    print(locals())
    print(globals())

l = [11,22,33]

f1()

#>>>>>>>>>>>>>>>>>>>>>

{'n1': 123}
{'__loader__': <_frozen_importlib_external.SourceFileLoader object at 0x000001F7B1AEAA58>, 'f1': <function f1 at 0x000001F7B1BB10D0>, '__spec__': None, 'l': [11, 22, 33], '__file__': 'C:/Users/LiuKai/PycharmProjects/Fighting/main/src.py', '__package__': None, '__builtins__': <module 'builtins' (built-in)>, '__doc__': None, '__name__': '__main__', '__cached__': None}

  id() 内存地址

  hash() 返回其哈希值

  iter() 转为可迭代的对象,使用next()取值,每执行一次next()取下一个值

  max() min() 取最大值 最小值 sum() 求和

  pow() 指数运算 pow(2, 10) = 1024

  repr() 类似 ascii() , 不过 ascii() 遇到中文会转义

  reversed() 反转 需要在迭代(for循环)中取出元素

  round() 四舍五入

  zip() 把对应的元素组成一个元组作为一个元素

l = [11, 22, 33, 44, 55]
m = ['qq', 'ss', 'dd', 'dd']
n = ['@@', '##', '$$', '%%']

r = zip(l, m, n)

for i in r:
    print(i)

#>>>>>>>>>
(11, 'qq', '@@')
(22, 'ss', '##')
(33, 'dd', '$$')
(44, 'dd', '%%')

  __import__() 也是导入模块,r = __import__(random), 之后再用到时使用 r.randomrange() 相当于起了一个别名

 

  sorted() 排序顺序

  对数字来说,从小到大

  对字符串来说, 先数字,后字母字符,最后汉字

  

l = [ '你好','11', 'yadlan', '1324', '23', '546', 'rruhvd', 'Ancskdna', 'Av s,', '好啊']

r = sorted(l)

print(r)
for i in r:
    print(bytes(i, encoding = 'utf-8'))
    
#>>>>>>>>>>>>
['11', '1324', '23', '546', 'Ancskdna', 'Av s,', 'rruhvd', 'yadlan', '你好', '好啊']
b'11'
b'1324'
b'23'
b'546'
b'Ancskdna'
b'Av s,'
b'rruhvd'
b'yadlan'
b'\xe4\xbd\xa0\xe5\xa5\xbd'
b'\xe5\xa5\xbd\xe5\x95\x8a'

    

文件操作

  

 

posted @ 2017-03-20 21:38  云中王  阅读(210)  评论(0编辑  收藏  举报