python 内置函数 lamda表达式。 open 文件方法

lamda 表达式

lambda表达式

学习条件运算时,对于简单的 if else 语句,可以使用三元运算来表示,即:
普通的条件语句
if 1 == 1:
    name = 'kaixin'
else:
    name = 'gege'
print(name)

三元运算表示方法

name = 'kaixin' if 1 == 1 else 'gege'
print(name)


对于简单的函数,也存在一种简便的表示方式,即:lambda表达式

lambda  表达式  简单函数的简单表示方式
创建形式参数   创建函数内容 并把结果 a+1 return
func = lambda a:a+1  #定义函数  冒号前边是参数,后边是函数体,函数内部执行的代码只能是一行
ret = func(32)        
print(ret)

 







abs 绝对值 i = abs(123) print(i) bool,判断真假,把一个对象转换成布尔值,None,"" [] {} () # all 循环序列参数,如果每个元素都为真,那么all的返回值则为真 #如果列表里有一个元素是假的就是Fales r = all([123,345,None]) print(r) # any 只有一个真 则为真 整体的返回值就是真 i = any([None,'',[],{},(),1]) print(i) ascii() #对象的类中找类型的功能获取其返回值 #自动执行int类型里的repe方法把返回值赋给 ret ret = ascii(8) ==int.__repr__() class Foo: def __repr__(self): return 'bbbb43fdsffdb' f = Foo() ret = ascii(f) print(ret) #二进制 0b1010 就是二进制 r = bin(11) print(r) r1 = oct(8) #八进制 print(r1) r = int(10) #十进制 print(r) r = hex(10) #十六进制 print(r) #二进制转换十进制 int(10) i = int('0b11',base=2) print(i) #八进制转十进制 i = int ('11',base=8) print(i) #十六进制转十进制 i = int ('0xe',base=16) print(i) str #字符串 list #列表 bytearray 汉字转换字节数组 p = bytearray('郭凯欣',encoding='utf-8') print(p) bytes 字节转换字符串 bytes('xxxx',encoding='utf-8')
callable() 是否可执行 f = lambda x:x+1 print (f(5)) callable(f) #返回True chr() #把数字转换成ascii码字符 ord() #把ascii码字符转换成数字 一个字节,8位, 2**8,256: A B c( 只限于ascii码 #把数字转换成字符 c = chr(66) print(c) #把字符转换成数字 i = ord('t') print(i) eval() 可以执行一个字符串的表达式 .得 8 赋给返回值 i = eval('3+5') print(i) map #接收两个参数 (函数。可以迭代的对象) li = [11,22,33,] new_li = map(lambda x:x+100,li)  lamda表达式添加序号 def func(x): return x+100 new_li = map(func,li) print(list(new_li)) l = list(new_li) print(l) for i in new_li: print(i) filter 过滤 循环可以迭代的对象,获取每一个参数函数(参数) li = [123,234,345,456] def func(x): if x>33: return True else: return False print(li) print(filter(func,li)) n = filter(func,li) print(list(n)) max() #取最大值 i = max(11,22,33,456) print(i) min() #取最小值 i = min(11,22,33,456) print(i) i = round(2.7) #四舍五入 print(i)

li =[1,2,3]
print(help(li)) #显示所有变量或类的介绍
print(dir(li))  #查看变量或者类型,可以使用的函数,属性,如果是类必须用引号
print(type(li)) #查看类型
print(id(li))   #  查看id地址
locals  当前的局部变量
globals 当前的全局量。

 

 

 

divmod(a,b)方法返回的是a//b(除法取整)以及a对b的余数,返回结果类型为tuple
# a = 10 / 3 
# print(a) 
D:\python3.5\python.exe D:/untitled/python2/denglu.py
3.3333333333333335
a = divmod(10,3)
print(a)
D:\python3.5\python.exe D:/untitled/python2/denglu.py
(3, 1)
eval 执行字符串形式的表达是
a = eval('1 + 3')
print(a)
D:\python3.5\python.exe D:/untitled/python2/denglu.py
4
isinstance()判断某个对象是否是某一个类创建的,如果是返回True,否则False
li = [11,'wqwq']
q = isinstance(li,int) 
print(q)
D:\python3.5\python.exe D:/untitled/python2/denglu.py
False
li = [11,'wqwq']
q = isinstance(li,list)
print(q)
D:\python3.5\python.exe D:/untitled/python2/denglu.py
True

pow()指数
a = pow(2,30) 
print(a)
D:\python3.5\python.exe D:/untitled/python2/denglu.py
1073741824
sum求和
a =sum([1,2,3,4,4,5,4,]) 
print(a)
D:\python3.5\python.exe D:/untitled/python2/denglu.py
23

zip函数接受任意多个(包括0个和1个)序列作为参数,返回一个tuple列表。
li = [1,2,3,4] 
qi = ['a','b'] 
a = zip(li,qi) 
for i in a:     
  print(i)
D:\python3.5\python.exe D:/untitled/python2/denglu.py
(1, 'a')
(2, 'b')

 

random验证码

 

# import random 导入  随机模块,
 #验证码的操作
random.randint(1,99)   #随机数字
temp = ''   定义一个空字付串
for i in range(6):  循环6次
    q = random.randrange(0,4)  自动生成一个0-4的随机数
    if q == 3 or q == 1:    如果随机数等于3 或 1就生成小写字母
        c2 = random.randrange(0,10)  生成 0--10内的随机数
        temp = temp + str(c2)   向变量中添加当前数字对应的ascii码的字符
    else:
        c = random.randrange(65,91) 生成 65-91内的随机数
        z = chr(c)
        temp = temp + z  向变量中添加当前数字对应的ascii码的字符
print(temp)

 

open函数,该函数用于文件处理

操作文件时,一般需要经历如下步骤:

  • 打开文件
  • 操作文件
  • 关闭文件
  • open(文件名,模式,编码)
    
    先创建一个ha.log文件
    
    f = open('ha.log')  #打开文件
    data = f.read()     #读取文件
    f.close()          #关闭文件
    print(data)       #打印文件内容
    

     

 打开文件时,需要指定文件路径和以何等方式打开文件,打开后,即可获取该文件句柄,日后通过此文件句柄对该文件操作。

打开文件的模式有:
•r ,只读模式【默认】
•w,只写模式【不可读;不存在则创建;存在则清空内容;】
•x, 只写模式【不可读;不存在则创建,存在则报错】
•a, 追加模式【可读;   不存在则创建;存在则只追加内容;】

#默认的是只读模式  默认的utf-8编码模式
f = open('da','r')
z = f.read()
f.close()
print(z)

# 只写模式  不加编码会乱码
f = open('da','w',encoding='utf-8')
f.write('世界')
f.close()

# 只写 不存在创建 存在则报错
f = open('da','x',encoding='utf-8')
f.write('世界')
f.close()

# 追加 a
f = open('da','a')
f.write('456')
f.close()

 
"+" 表示可以同时读写某个文件
•r+, 读写【可读,可写】
•w+,写读【可读,可写】
•x+ ,写读【可读,可写】
•a+, 写读【可读,可写】

#带r+号,即可读可写
# w 写的时候,默认在末尾追加 指针到最后
f = open('ha2.log','r+',encoding='utf-8')
print(f.tell())  # 指针为零 ,起始位置
data = f.read(3)
print(type(data),data)
print(f.tell())
f.write('萨比‘)
data = f.read()
print(type(data),data)
f.write('日本人')
f.seek(0)
f.close()

#  w+ 会先情空,写完之后才可以读了,写 ,指针到最后
f = open('ha.log','w+',encoding='utf-8')
f.write('别傻了老弟')
data = f.read()
f.close()
print(data)
#x+跟w+一样,唯一不同的是如果文件存在则报错

# a+  打开的同时,指针就在最后
f = open('ha.log','a+',encoding='utf-8')
print(f.tell())
data = f.read()
print(data)
f.seek(0)
data = f.read()
print(data)
f.close()

 


 "b"表示以字节的方式操作
•rb  或 r+b
•wb 或 w+b
•xb 或 w+b
•ab 或 a+b

注:以b方式打开时,读取到的内容是字节类型,写入时也需要提供字节类型

f = open('da','rb')
data =f.read()
f.close()
print((data))
str_data = str(data,encoding='utf-8')
print(str_data)

f = open('da','wb')
str_data = '世界'
bytes_data = bytes(str_data,encoding='utf-8')
f.write(bytes_data)
f.close()

f = open('da','wb')
f.write(bytes('中国',encoding='utf-8'))
f.close()
str_data = '世界'
bytes_data = bytes(str_data,encoding='utf-8')
f.write(bytes_data)
f.close()

 

 

f = open('da','r+',encoding='utf-8')   #打开文件
s = f.read()  #读取内容 
s = f.read(1)  #读取内容后的第一个字节
f.close          # 关闭文件
print(s)


f = open('da','w+',encoding='utf-8')
f.write('beicui')     #写入内容
    

f = open('da','r+',encoding='utf-8')
s = f.tell()        # 查看指针当前位置
print(s)
a = f.seek(2)   #调整指针的位置
print(a)

f = open('da','r+',encoding='utf-8')
s = f.fileno()   #文件描述符
print(s)

f = open('da','r+',encoding='utf-8')
f.write('1去玩儿童体验与西欧')
s = f.flush()   #强制刷入内存
print(s)

f = open('da','r+',encoding='utf-8')
print(f.readline())  #读取一行内容

f = open('da','r+',encoding='utf-8')
f.seek(5)
s = f.truncate()  #截取位置前的字符
print(s)

f = open('da','r+',encoding='utf-8')
s = f.readlines()  #以列表的形式显示
print(s)

with open('da',"r") as f:  #打开方式

py2.7之后支持同时打开两个文件:
with open("da1","r") as f1,open("da","r") as f2:

 

posted @ 2016-05-10 13:17  起来了皮  阅读(638)  评论(0编辑  收藏  举报