Python3.0内置函数

abs() 取数字的绝对值,也就是无论是正数还是负数取它的绝对值
格式:abs(目标变量)
返回:数字类型
#!/usr/bin/env python
# -*- coding:utf-8 -*-
#abs() 取数字的绝对值,也就是无论是正数还是负数取它的绝对值
a = 123
b = abs(a)
print(b)
#输出 123 a1= -123
b1 = abs(a1)
print(b1)
#输出 123

all() 接收可迭代类型,循环参数,如果每个元素都为真,那么all的返回值为真,有一个元素为假返回的都是假

格式:all(目标变量)

假数据有,0(数字),None(返回值),"" (空字符串),[] (空列表),() (空元组),{} (空字典)

返回:布尔值

#!/usr/bin/env python
# -*- coding:utf-8 -*-
#all() 接收可迭代类型,循环参数,如果每个元素都为真,那么all的返回值为真,有一个元素为假返回的都是假
#假数据有,0(数字),None(返回值),"" (空字符串),[] (空列表),() (空元组),{} (空字典) #列1
a = [1,"",[123,456],(123,456),{"k1":123,"k2":456}]
f1 = all(a)
print(f1)
#输出 True (真) #列2
b = [0,"你好",[123,456],(123,456),{"k1":123,"k2":456}]
f2 = all(b)
print(f2)
#输出 False (假)说明:里面的类型中有一个或者多个为假

any() 接收可迭代类型,循环参数,如果有一个元素都为真,那么all的返回值为真,全部为假才返回假
格式:any(目标变量)
假数据有,0(数字),None(返回值),"" (空字符串),[] (空列表),() (空元组),{} (空字典)
返回:布尔值
#!/usr/bin/env python
# -*- coding:utf-8 -*-
#any() 接收可迭代类型,循环参数,如果有一个元素都为真,那么all的返回值为真,全部为假才返回假
#假数据有,0(数字),None(返回值),"" (空字符串),[] (空列表),() (空元组),{} (空字典) #列1
a = [0,"",[],(),{}] #其中有1个为真
f1 = any(a)
print(f1)
#输出 True (真) #列2
b = [0,"",[],(),{}] #全部为假
f2 = all(b)
print(f2)
#输出 False (假)说明:里面的类型全部为假
ascii() 根据对象,在对象类中找到 _repr_ 获取其返回值,中文返回ascii()码
格式: ascii(目标变量)
返回:对应的类型,中文返回ascii()码
#!/usr/bin/env python
# -*- coding:utf-8 -*-
#ascii() 根据对象,在对象类中找到 _repr_ 获取其返回值,中文返回ascii()码
a = 1234
b = ascii(a)
print(b)
#返回 1234 #如果是中文字符串转换成ascii码返回
a1 = "林贵秀"
b1 = ascii(a1)
print(b1) #中文字符串转换成ascii码返回
#返回 '\u6797\u8d35\u79c0'
 
bin() 二进制表示,十进制转换二进制
格式:bin(目标变量)
返回:二进制
#!/usr/bin/env python
# -*- coding:utf-8 -*-
#bin() 二进制表示
a = 12
b = bin(a)
print(b)
#返回 0b1100 (0b表示二进制的意思)

oct() 八进制表示,十进制转换八进制 

格式:oct(目标变量)

返回:八进制


#!/usr/bin/env python
# -*- coding:utf-8 -*-
#oct() 八进制表示
a = 123
b = oct(a)
print(b)
#返回 0173 (0表示八进制的意思)

int() 十进制表示,十进制转换十进制
格式:int(目标变量)
返回:十进制
#!/usr/bin/env python
# -*- coding:utf-8 -*-
#int() 十进制表示
a = 123987
b = int(a)
print(b)
#返回 123987 (表示十进制的意思)

hex() 十六进制表示,十进制转换十六进制
格式:hex(目标变量)
返回:十六进制
#!/usr/bin/env python
# -*- coding:utf-8 -*-
#hex() 十六进制表示
a = 123987
b = hex(a)
print(b)
#返回 0x1e453 (0x表示十进制的意思)

int()  二进制转换成十进制
格式:int(目标变量,base=2 )
返回:十进制
#!/usr/bin/env python
# -*- coding:utf-8 -*-
#int() 二进制转换成十进制
a = "0b1100"
b = int(a,base=2)
print(b)
#返回 12 表示十进制的意思

int()  八进制转换成十进制
格式:int(目标变量,base=8 )
返回:十进制
#!/usr/bin/env python
# -*- coding:utf-8 -*-
#int() 八进制转换成十进制
a = ""
b = int(a,base=8)
print(b)
#返回 123 表示十进制的意思
int()  十进制转换成十进制
格式:int(目标变量,base=10 )
返回:十进制
#!/usr/bin/env python
# -*- coding:utf-8 -*-
#int() 十进制转换成十进制
a = ""
b = int(a,base=10)
print(b)
#返回 123987 表示十进制的意思
int()  十六进制转换成十进制
格式:int(目标变量,base=16 )
返回:十进制
#!/usr/bin/env python
# -*- coding:utf-8 -*-
#int() 十六进制转换成十进制
a = "0x1e453"
b = int(a,base=16)
print(b)
#返回 123987 表示十进制的意思

bool() 判断真假,把一个对象转换成布尔值
假数据有,0(数字),None(返回值),"" (空字符串),[] (空列表),() (空元组),{} (空字典)
格式:bool(目标变量)
返回:假返回False 真返回True

#!/usr/bin/env python
# -*- coding:utf-8 -*-
#bool() 判断真假,把一个对象转换成布尔值
a1 = ""
b = bool(a1)
print(b)
#返回 False 表示a1空字符串为假

bytes() 字符串转换成字节
格式:bytes(目标变量,encoding="utf-8")
返回:字节码

#!/usr/bin/env python
# -*- coding:utf-8 -*-
#bytes() 字符串转换成字节
a = "林贵秀"
b = bytes(a, encoding = "utf-8")
print(b)
#返回 b'\xe6\x9e\x97\xe8\xb4\xb5\xe7\xa7\x80' 字节

decode()将二进制字节类型解码成字符串

格式:字节码变量.decode("utf-8") 

#!/usr/bin/env python
# -*- coding:utf8 -*-
#bytes() 字符串转换成字节
a = "林贵秀"
b = bytes(a, encoding = "utf-8")
print(b)
#返回 b'\xe6\x9e\x97\xe8\xb4\xb5\xe7\xa7\x80' 字节
f = b.decode("utf-8")
print(f)
#输出
# b'\xe6\x9e\x97\xe8\xb4\xb5\xe7\xa7\x80'
# 林贵秀

str() 将字节转换成字符串
格式:str(目标变量,encoding="utf-8")
返回:字符串

#!/usr/bin/env python
# -*- coding:utf-8 -*-
"""str() 将字节转换成字符串"""
#bytes() 字符串转换成字节
a = "林贵秀"
b = bytes(a, encoding = "utf-8")
print(b)
#返回 b'\xe6\x9e\x97\xe8\xb4\xb5\xe7\xa7\x80' 字节 #str() 将字节转换成字符串
c = str(b, encoding = "utf-8")
print(c)
#返回 林贵秀 字符串

bytearray() 将字符串转换成字节列表
格式:bytearray(目标变量,encoding="utf-8")
返回:字节列表

#!/usr/bin/env python
# -*- coding:utf-8 -*-
#bytearray() 字节列表
a = "林贵秀"
b = bytearray(a, encoding="utf-8")
print(b)
#返回 bytearray(b'\xe6\x9e\x97\xe8\xb4\xb5\xe7\xa7\x80') 字节列表 #字节列表也可以用str()转换成字符串
c = str(b, encoding="utf-8")
print(c)
#返回 林贵秀 字符串

chr() 将十进制ascii码转换成对应的(英文,字符,数字)
格式:chr(目标变量)
返回:对应的(英文,字符,数字)

详情见:ascii码对照表

#!/usr/bin/env python
# -*- coding:utf-8 -*-
#chr() 将十进制ascii码转换成对应的(英文,字符,数字)
a = 77
b = chr(a)
print(b)
#返回 M ascii码对应的(英文,字符,数字)

ord() 将(英文,字符,数字)转换成十进制对应的ascii码
格式:ord(目标变量)
返回:十进制对应的ascii码

详情见:ascii码对照表

#!/usr/bin/env python
# -*- coding:utf-8 -*-
#ord() 将(英文,字符,数字)转换成十进制对应的ascii码
a = "M"
b = ord(a)
print(b)
#返回 77 十进制对应的ascii码

random 随机数模块
格式:
  import random 引入随机模块文件
  random.randrange(65,91) 调用随机函数random.randrange(随机数开始范围,随机数结束范围)

#!/usr/bin/env python
# -*- coding:utf-8 -*-
"""实现随机数"""
import random #引入随机模块文件
f1 = random.randrange(65,91) #调用随机函数random.randrange(随机数开始范围,随机数结束范围)
print(f1) #返回一个65至91之间的随机数
实现随机验证码
#!/usr/bin/env python
# -*- coding:utf-8 -*-
"""实现随机验证码""" """实现随机数"""
import random #引入随机模块文件
f1 = random.randrange(65,91) #调用随机函数random.randrange(随机数开始范围,随机数结束范围)
print(f1) #返回一个65至91之间的随机数 """实现8位数字随机数"""
suij = "" #统计随机数
for i in range(4): #循环4次
rad = random.randrange(65,91) #每一次循环随机一个65至91之间的一个数赋值rad变量
c = str(rad) #将每次得到的随机数转换成字符串类型
suij = suij + c #将转换成字符串类型的随机数赋值给,统计随机数
print(suij) #打印出统计随机数 """实现4位字母随机数130"""
suij2 = "" #统计随机数
for i in range(4): #循环4次
rad = random.randrange(65,91) #每一次循环随机一个65至91之间的一个数赋值rad变量
c = chr(rad) #将每次得到的随机数以十进制的ascii码转换成对应字母(ascii码字母范围是65-91)
suij2 += c #将转换的字母赋值给,统计随机数
print(suij2) #打印出统计随机数 """实现随机数字字母的组合"""
suij3 = "" #统计随机数
for i in range(4): #循环4次
rad1 = random.randrange(0,6) #每一次循环随机一个0至6之间的一个数
if rad1 == 1 or rad1 == 3: #判断如果rad1变量随机数等于1或者等于3
rad2 = random.randrange(65,91) #每一次循环随机一个65至91之间的一个数
c1 = str(rad2) #将随机数转换成字符串
suij3 = suij3 + c1 #将转换的字符串赋值给,统计随机数
else: #如果rad1变量随机数不等于1或者3
rad3 = random.randrange(65,91) #每一次循环随机一个65至91之间的一个数
c2 = chr(rad3) #将随机到的数以十进制的ascii码转换成对应字母
suij3 = suij3 + c2 #将转换的字母赋值给,统计随机数
print(suij3) #打印出统计随机数

callable() 一个对象是否可以被执行,也就是判断一个对象是否可以执行一个功能,如判断函数
格式:callable(目标变量)
返回:布尔值,可以执行返回True,不可以执行返回False

#!/usr/bin/env python
# -*- coding:utf-8 -*-
#callable() 一个对象是否可以被执行,也就是判断一个对象是否可以执行一个功能,如判断函数
def f1(a,b):
c = a + b
return c
f1(5,5)
r = callable(f1)
print(r)
#返回 True 表示可执行对象

dict() 字典,创建字典
格式:dict(目标变量)
返回:字典

#!/usr/bin/env python
# -*- coding:utf-8 -*-
#dict() 字典,创建字典
#创建字典
a = dict({"k1":123,"k2":456,"k3":789})
print(a)
#返回 {'k3': 789, 'k1': 123, 'k2': 456}

dir() 查看一个对象的类库所有功能
格式:dir(目标变量)
返回:对象的类库详情

#!/usr/bin/env python
# -*- coding:utf-8 -*-
#dir() 查看一个对象的类库所有功能
a = []
b = dir(a)
print(b)
#返回:对象的类库详情

help() 查看一个类的类库功能详情
格式:help(类名称)
返回:一个类的类库功能详情

#!/usr/bin/env python
# -*- coding:utf-8 -*-
#help() 查看一个类的类库功能详情
a = help(str)
print(a)
#返回 一个类的类库功能详情

divmod() 除数,判断除数结果,如果结果是整数返回整数加余数0,如果结果有小数返回整数加余数1
格式:divmod(除数,被除数)
返回:整数加余数1 ,整数加余数0

#!/usr/bin/env python
# -*- coding:utf-8 -*-
#divmod() 除数,判断除数结果,如果结果是整数返回整数加余数0,如果结果有小数返回整数加余数1
#除数结果是整数列
a = divmod(10,5)
print(a)
#返回 (2, 0) #除数结果有小数列
b = divmod(10,3)
print(b)
#返回 (3, 1)

enumerate() 自定义有序类型的起始索引,如:列表,元组等
格式:(目标变量,起始索引位置数)
返回:对应类型的索引自定义位置开始

#!/usr/bin/env python
# -*- coding:utf-8 -*-
#enumerate() 自定义有序类型的起始索引,如:列表,元组等
#列1
a = [123,456,789]
for k,v in enumerate(a,1):
print(k,v)
#返回
#1 123
#2 456
#3 789 #列2
b = [987,654,321]
c = enumerate(b,1)
for k,v in c:
print(k,v)
#返回
#1 987
#2 654
#3 321

eval() 计算字符串类型的算数
格式:eval(目标变量,赋值字典)
返回:计算结果

#!/usr/bin/env python
# -*- coding:utf-8 -*-
#eval() 计算字符串类型的算数
#列1
a = "3 + 2 - 5 + 1" #字符串类的表达式
b = eval(a) #计算字符串类的表达式
print(b) #返回结果
#返回 1 #列2
b1 = eval("f + 5",{"f":8}) #f+5,相当于f是一个变量+5,后面可以传一个字典,就相当于赋值f变量等于8
print(b1) #返回结果
#返回 13

exec() 执行字符串类型的代码
格式:exec(目标变量)
返回:无返回值,只执行字符串类型的代码

#!/usr/bin/env python
# -*- coding:utf-8 -*-
#exec() 执行字符串类型的代码
#列1
a1 = "for i in range(8): print(i)" #字符串类型的一个8次循环
b1 = exec(a1) #执行字符串代码 #列2
a = "for i in range(x): print(i)" #字符串类型的一个8次循环
b = exec(a,{"x":8}) #后面可以传一个字典,就相当于赋值x变量等于8

filter() 帅选一个可迭代对象,循序一个可迭代对象,将每次循环到的元素传入一个判断函数,判断函数返回True就将此元素保留,返回False的元素不保留
格式:filter(函数,可迭代对象)
返回:函数返回True的元素

#!/usr/bin/env python
# -*- coding:utf-8 -*-
#filter() 循序一个可迭代对象,将每次循环到的元素传入一个判断函数,判断函数返回True就将此元素保留,返回False的元素不保留
#列1
def f1(x):
if x > 5: #判断函数传入的参数是否大于5
return True #如果大于5返回True
else:
return False #如果不大于5返回False
a = filter(f1,[1,2,3,4,5,6,7,8,9]) #循环可迭代对象每次循环到的元素传入f1函数,每次传入函数返回True的元素保留给a变量,返回False 的元素不保留
for i in a: #循环出保留的元素
print(i) #打印出保留的元素
#打印出
#
#
#
# #列2
#用lambda的表达式创建函数
a1 = filter(lambda x: x > 5 ,[1,2,3,4,5,6,7,8,9]) #循环可迭代对象每次循环到的元素传入f1函数,每次传入函数返回True的元素保留给a变量,返回False 的元素不保留
for i in a1: #循环出保留的元素
print(i) #打印出保留的元素
#打印出
#
#
#
#

map() 对一个可迭代对象的每个元素做一种操作,返回以处理后的元素
格式:map(函数,可迭代对象)
返回:返回以处理后的元素

#!/usr/bin/env python
# -*- coding:utf-8 -*-
#map() 对一个可迭代对象的每个元素做一种操作,返回以处理后的元素
#列1
def f1(x):
return x + 100 #将函数接收到的参数加100返回
a = map(f1,[1,2,3,4,5]) #循环列表将每次循环的元素传入函数,将每次函数返回结果赋值给a变量
for i in a: #循环出结果赋值的变量
print(i) #打印结果
#输出
#
#
#
#
# #列2
#用lambda表达式创建函数
a1 = map(lambda x: x + 100, [1,2,3,4,5])
for i in a1:
print(i)
#输出
#
#
#
#
#

globals() 获取当前代码里的所有全局变量
格式:print(globals())
返回:当前代码里的所有全局变量

#!/usr/bin/env python
# -*- coding:utf-8 -*-
#globals() 获取当前代码里的所有全局变量
a = 123
b = 456
c = 789
print(globals())
#返回:当前代码里的所有全局变量

locals() 获取当前代码里的所有局部变量
格式:print(locals())
返回:当前代码里的所有局部变量

#!/usr/bin/env python
# -*- coding:utf-8 -*-
#locals() 获取当前代码里的所有局部变量
def f1():
a = 123
b = 456
c = 789
print(locals()) #获取当前代码里的所有局部变量
f1()

hash() 计算一个字符串的哈希值
格式:hash(目标变量)
返回:哈希值

#!/usr/bin/env python
# -*- coding:utf-8 -*-
#hash() 计算一个字符串的哈希值
a = "ihdaho;uybvy8h9adghoda"
b = hash(a)
print(b)
#返回 2278432038003157021 哈希值

help() 查看类的帮助信息
格式:help(type(a))
返回:帮助信息

#!/usr/bin/env python
# -*- coding:utf-8 -*-
#help() 查看类的帮助信息
a = "ihvfijwj"
b = help(type(a))
print(b)
#返回:帮助信息

id() 获取对象的内存地址
格式:id(目标变量)
返回:对象内存地址

#!/usr/bin/env python
# -*- coding:utf-8 -*-
#id() 获取对象的内存地址
a = "ewjwehnig"
b = id(a)
print(b)
#返回:对象内存地址

input() 等待用户输入
格式:变量 = input()
返回:用户输入信息

#!/usr/bin/env python
# -*- coding:utf-8 -*-
#input() 等待用户输入
a = input()
print(a)
#返回:用户输入信息

int() 创建或者转换整数类型
格式:int(目标变量)
返回:整数

#!/usr/bin/env python
# -*- coding:utf-8 -*-
#int() 创建或者转换整数类型
#创建整数
a = int(1234)
print(a) #转换整数
b = ""
c = int(b)
print(c)
#返回:整数

isinstance() 判断一个对象是否是某个类型
格式:isinstance(目标对象,类型)
返回:如果是对应的类型True,不是对应的类型False

#!/usr/bin/env python
# -*- coding:utf-8 -*-
#isinstance() 判断一个对象是否是某个类型
a = "林贵秀"
b = isinstance(a,str)
print(b)
#返回 True

iter() 创建可迭代的对象,结合next()取出里面的每个元素
格式:iter(目标变量)
返回:可迭代类型
可结合next()取出里面的每个元素

#!/usr/bin/env python
# -*- coding:utf-8 -*-
#iter() 创建可迭代的对象
a = "rghrthrhkjhtr"
b = iter(a) #创建可迭代的对象
print(b)
c1 = next(b) #取出里面一个元素
print(c1)
c2 = next(b) #取出里面一个元素
print(c2)
c3 = next(b) #取出里面一个元素
print(c3)
# 返回:可迭代类型
# 可结合next()取出里面的每个元素

next()取出可迭代类型里面的每个元素,结合iter()使用
格式:next(目标对象)
返回:可迭代类型的一个元素

#!/usr/bin/env python
# -*- coding:utf-8 -*-
#iter() 创建可迭代的对象
a = "rghrthrhkjhtr"
b = iter(a) #创建可迭代的对象
print(b)
c1 = next(b) #取出里面一个元素
print(c1)
c2 = next(b) #取出里面一个元素
print(c2)
c3 = next(b) #取出里面一个元素
print(c3)
# 返回:可迭代类型
# 可结合next()取出里面的每个元素

len() 判断一个可迭代对象里面有多少个元素
格式:len(目标对象)
返回:可迭代对象里面元素的数量

#!/usr/bin/env python
# -*- coding:utf-8 -*-
#len() 判断一个可迭代对象里面有多少个元素
a = ""
b = len(a)
print(b)
# 返回:可迭代对象里面元素的数量

max() 取一个可迭代对象的最大值
格式:max(目标变量)
返回:最大值

#!/usr/bin/env python
# -*- coding:utf-8 -*-
#max() 取一个可迭代对象的最大值
a = ""
b = max(a)
print(b)
# 返回:最大值

min() 取一个可迭代对象的最小值
格式:min(目标变量)
返回:最小值

#!/usr/bin/env python
# -*- coding:utf-8 -*-
#min() 取一个可迭代对象的最小值
a = ""
b = min(a)
print(b)
# 返回:最小值

pow() 求一个数的对少次方
格式:pow(要求的数,多少次方)
返回:一个数的次方

#!/usr/bin/env python
# -*- coding:utf-8 -*-
#pow() 求一个数的对少次方
a = pow(2,10) #2的10次方
print(a)
#返回 1024

property() 打印结果
格式:property(目标变量)
返回:结果

#!/usr/bin/env python
# -*- coding:utf-8 -*-
#property() 打印结果
a = 12345
print(a)
#返回 12345 结果

range() 自动创建一个数字列表,py3.0以上版本需要for循环后才创建
格式:range(开始数字,结束数字)
返回:需要for循环后返回创建的元素

#!/usr/bin/env python
# -*- coding:utf-8 -*-
#range() 自动创建一个列表
a = range(1,10) #如果传一个参数,默认从0开始
for i in a:
print(i)
#返回 需要for循环后返回创建的元素

repr() 在对象类中找到 _repr_ 获取其返回值,返回对应的类型
格式:repr(目标变量)
返回:对应的类型

#!/usr/bin/env python
# -*- coding:utf-8 -*-
#repr()在对象类中找到 _repr_ 获取其返回值,返回对应的类型
a = 1234
b = repr(a)
print(b)
#返回 1234 a1 = "林贵秀"
b1 = repr(a1)
print(b1)
#返回 '林贵秀'

reversed() 对可迭代类型的元素排序进行反转,需要for循环后返回
格式:reversed(目标变量)
返回:需要for循环后返回,将元素进行反转排序后返回

#!/usr/bin/env python
# -*- coding:utf-8 -*-
#reversed() 对可迭代类型的元素排序进行反转,需要for循环后返回
a = ""
b = reversed(a)
for i in b:
print(i)
# 返回
#
#
#
#

round() 四舍五入
格式:round(目标变量)
返回:四舍五入

#!/usr/bin/env python
# -*- coding:utf-8 -*-
#round() 四舍五入
#四舍
a = 3.4
b = round(a)
print(b)
#返回 3 #五入
a1 = 5.5
b1 = round(a1)
print(b1)
#返回 6

set() 创建或转换无序集合
格式:set(目标变量)
返回:无序集合

#!/usr/bin/env python
# -*- coding:utf-8 -*-
#set() 创建或转换无序集合
#创建结合
a1 = set({1,2,3})
print(a1)
#返回 {1, 2, 3} #转换集合
a = [1,2,3,4,5]
b = set(a)
print(b)
#返回 {1, 2, 3, 4, 5}

sum() 将一个可迭代对象的数字元素求和
格式:sum(目标变量)
返回:求和

#!/usr/bin/env python
# -*- coding:utf-8 -*-
#sum() 将一个可迭代对象的数字元素求和
a = [11,22,33,44]
b = sum(a)
print(b)
#返回 110 求和

tuple() 创建或转换元组
格式:tuple(目标变量)
返回:元组

#!/usr/bin/env python
# -*- coding:utf-8 -*-
#tuple() 创建或转换元组
#创建元组
a = tuple((11,22,33,44))
print(a)
#返回 (11, 22, 33, 44) #转换元组
a1 = [11,22,33,44]
b1 = tuple(a1)
print(b1)
#返回 (11, 22, 33, 44)

type() 查看一个对象的类型
格式:type(目标变量)
返回:类型

#!/usr/bin/env python
# -*- coding:utf-8 -*-
#type() 查看一个对象的类型
a = "你好"
b = type(a)
print(b)
#返回类型 <class 'str'>

zip() 将两个列表的元素,组合成两个元素为一对元组,需要for循环后返回
格式:zip(列表,列表)
返回:需要for循环后返回,两个元素为一对元组

#!/usr/bin/env python
# -*- coding:utf-8 -*-
#zip() 将两个列表的元素,组合成两个元素为一对元组,需要for循环后返回
a = [1,2,3,4,5]
b = ["a","b","c","d","e"]
c = zip(a,b)
print(c) #<zip object at 0x0000012584DA0F88>
for i in c:
print(i)
#返回
# (1, 'a')
# (2, 'b')
# (3, 'c')
# (4, 'd')
# (5, 'e')

sorted() 对可迭代对象排序,注意可迭代对象元素一定要是同一类型,否则不能排序
格式:sorted(目标变量)
返回:排序后的对应对象

#!/usr/bin/env python
# -*- coding:utf-8 -*-
#sorted() 对可迭代对象排序,注意可迭代对象元素一定要是同一类型,否则不能排序
#数字排序,数字从小到大排序
a = [6,3,8,2,9,7,5]
b = sorted(a)
print(b)
#返回 [2, 3, 5, 6, 7, 8, 9] #字母排序,字母按照顺序排序
a1 = ["d","f","s","e","a","u","g","l"]
b1 =sorted(a1)
print(b1)
#返回 ['a', 'd', 'e', 'f', 'g', 'l', 's', 'u'] #字符串排序,是按照字符串的字节码数字和字母的ascii码排序的
a2 = "自贡玉秀文化传播有限公司"
b2 = sorted(a2)
print(b2)
#返回 ['传', '公', '化', '司', '播', '文', '有', '玉', '秀', '自', '贡', '限'] for i in b2:
print(bytes(i,encoding="utf-8")) #查看字符串的字节码

文件操作
文件操作的步骤
1.打开文件: open()打开文件
2.操作文件: read()读出文件,write()写入文件
3.关闭文件: close()关闭文件

open() 打开一个文件
格式:句柄变量 = open(要打开的文件名或文件路径,打开模式,编码)
注意:默认是只读模式
注意:编码只有在普通模式的时候用(3.0版本默认是utf-8编码),字节码模式不需要编码因为基层就是字节码保存的
返回:文件句柄

#!/usr/bin/env python
# -*- coding:utf-8 -*-
#open() 打开一个文件
f = open("h.log", "r", encoding="utf-8") #打开h.log文件,以r模式(只读)打开,以utf-8编码
print(f) #打印文件句柄,<_io.TextIOWrapper name='h.log' mode='r' encoding='utf-8'>
f1 = f.read() #read()读出文件内容
f.close() #关闭文件
print(f1) #读出文件内容,tjhutrjtr

read() 读出文件内容
格式:句柄变量.read(位数从指针位置开始向后读多少位)  默认全部读出
返回:文件里的内容

#!/usr/bin/env python
# -*- coding:utf-8 -*-
#read() 读出文件内容
f = open("h.log", "r", encoding="utf-8") #打开h.log文件,以r模式(只读)打开,以utf-8编码
print(f) #打印文件句柄,<_io.TextIOWrapper name='h.log' mode='r' encoding='utf-8'>
f1 = f.read() #read()读出文件内容
f.close() #关闭文件
print(f1) #读出文件内容,tjhutrjtr

write() 写入文件
格式:句柄变量.write(要写入的内容)
返回:无返回,将内容写入文件

#!/usr/bin/env python
# -*- coding:utf-8 -*-
#write() 写入文件
f = open("h.log", "w", encoding="utf-8") #打开h.log文件,以r模式(只读)打开,以utf-8编码
f1 = f.write("林贵秀") #write()写入文件内容
f.close() #关闭文件

close() 关闭文件
格式:句柄变量.close()
返回:无,关闭打开的文件

#!/usr/bin/env python
# -*- coding:utf-8 -*-
#read() 读出文件内容
f = open("h.log", "r", encoding="utf-8") #打开h.log文件,以r模式(只读)打开,以utf-8编码
print(f) #打印文件句柄,<_io.TextIOWrapper name='h.log' mode='r' encoding='utf-8'>
f1 = f.read() #read()读出文件内容
f.close() #关闭文件
print(f1) #读出文件内容,tjhutrjtr

打开文件的模式有:

  • r ,只读模式【默认】
  • #!/usr/bin/env python
    # -*- coding:utf-8 -*-
    #r ,只读模式【默认】
    f = open("h.log", "r", encoding="utf-8") #打开h.log文件,以r模式(只读)打开,以utf-8编码
    f2 = f.read() #read()读出文件
    print(f2)
    f.close() #关闭文件
    # 只能读,不能写入

    下面相同原理

  • w,只写模式【不可读;不存在则创建;存在则清空内容;】
  • x, 只写模式【不可读;不存在则创建,存在则报错】
  • a, 追加模式【可读;   不存在则创建;存在则只追加内容;】

"+" 表示可以同时读写某个文件

  • r+, 读写【可读,可写】
#!/usr/bin/env python
# -*- coding:utf-8 -*-
#r ,只读模式【默认】
f = open("h.log", "r+", encoding="utf-8") #打开h.log文件,以r+模式(读写)打开,以utf-8编码
f2 = f.read() #read()读出文件
print(f2)
f.write("") #写入文件
f.close() #关闭文件
# 可读,可写

  下面相同原理

  • w+,写读【可读,可写,不存在则创建;存在则清空内容;
  • x+ ,写读【可读,可写,不存在则创建,存在则报错
  • a+, 写读【可读,可写,不存在则创建;存在则只追加内容;

 "b"表示以字节的方式操作,以b方式打开时,读取到的内容是字节类型,写入时也需要提供字节类型

   注:以b方式打开时,读取到的内容是字节类型(不需要编码),写入时也需要提供字节类型(需要用bytes()转换成字节写入

  • rb 或 r+b 【原有基础上增加字节码模式】
#!/usr/bin/env python
# -*- coding:utf-8 -*-
#r+b 读写字节方式
f = open("h.log", "r+b") #打开h.log文件,以r+b模式(读写字节方式)
f2 = f.read() #read()读出文件内容字节
f3 = str(f2, encoding="utf-8") #将字节转换成字符串
print(f3) #打印出字符串 a = "你好"
b = bytes(a,encoding="utf-8") #注意:字节模式写入前一定要转换成字节
f.write(b) #写入文件
f.close() #关闭文件
# 可读,可写

  下面相同原理

  • wb 或 w+b  【原有基础上增加字节码模式】  
  • xb 或 w+b  【原有基础上增加字节码模式】
  • ab 或 a+b  【原有基础上增加字节码模式】

 

文件指针
操作文件,写入内容或者读出内容都是从指针位置开始向后操作的。
指针位置在开始位置后面的内容就可以读出,指针位置在结束的位置后面是空的此时读出就是空白

写入内容后指针就停留在写入内容的结束位置,追加模式写入内容是先将指针调到结束位置写入,写入后停留在写入结束位置
根据打开文件的模式不同指针位置不同,

 

tell() 查看文件指针位置
格式:句柄变量.tell()
返回:指针位置

#!/usr/bin/env python
# -*- coding:utf-8 -*-
#tell() 查看文件指针位置
#如:h.log里有一串字符串"自贡玉秀文化传播有限公司"
f = open("h.log", "r", encoding="utf-8") #打开h.log文件,以r只读模式,以utf-8编码
f1 = f.tell() #tell()获取文件指针位置,注意:中文字符一个汉字算3个指针
print(f1) #打印出指针位置 f.seek(9) #自定义文件指针位置
f2 = f.tell() #tell()获取文件指针位置,注意:中文字符一个汉字算3个指针
print(f2) #打印出指针位置 f3 = f.read() #读取文件内容
print(f3) #打印出文件内容
f.close() #关闭文件

seek() 自定义文件指针位置
格式:句柄变量.seek(自定义指针位置) 默认指针位置0
返回:无,自定义文件指针位置

#!/usr/bin/env python
# -*- coding:utf-8 -*-
#tell() 查看文件指针位置
#如:h.log里有一串字符串"自贡玉秀文化传播有限公司"
f = open("h.log", "r", encoding="utf-8") #打开h.log文件,以r只读模式,以utf-8编码
f1 = f.tell() #tell()获取文件指针位置,注意:中文字符一个汉字算3个指针
print(f1) #打印出指针位置 f.seek(9) #自定义文件指针位置
f2 = f.tell() #tell()获取文件指针位置,注意:中文字符一个汉字算3个指针
print(f2) #打印出指针位置 f3 = f.read() #读取文件内容
print(f3) #打印出文件内容
f.close() #关闭文件

flush() 刷新文件内部缓冲区(将内容刷到硬盘文件里)
格式:句柄变量.flush()
返回:无,将内容刷到硬盘文件里

下面是将内容刷到硬盘文件里,与不将内容刷到硬盘文件里的区别

1不将内容刷到硬盘文件里

#!/usr/bin/env python
# -*- coding:utf-8 -*-
#flush() 刷新文件内部缓冲区(将内容刷到硬盘文件里)
#不将内容刷到硬盘文件里
f = open("h.log", "w", encoding="utf-8") #打开h.log文件,以w只写,以utf-8编码
f.write("林贵秀") #写入内容
input() #等待用户输入,进程没结束
f.close() #关闭文件
#如上列说明,等待用户输入,只要用户没有输入信息确认进程就没结束,上面的内容就不会写入文件

2将内容刷到硬盘文件里

#!/usr/bin/env python
# -*- coding:utf-8 -*-
#flush() 刷新文件内部缓冲区(将内容刷到硬盘文件里)
f = open("h.log", "w", encoding="utf-8") #打开h.log文件,以w只写,以utf-8编码
f.write("林贵秀") #写入内容
f.flush() #将内容刷到硬盘文件里
input() #等待用户输入,进程没结束
f.close() #关闭文件
#如上列说明,等待用户输入,只要用户没有输入信息确认进程就没结束,上面的内容也会写入文件

readline() 仅读取一行数据,后面行的数据不读取
格式:句柄变量.readline()
返回:仅返回文件里一行数据

#!/usr/bin/env python
# -*- coding:utf-8 -*-
#readline() 仅读取一行数据
f = open("h.log", "r", encoding="utf-8") #打开h.log文件,以r只读模式,以utf-8编码
f1 = f.readline() #readline() 仅读取一行数据,后面行的数据不读取
print(f1)
f.close() #关闭文件

truncate() 截断数据,仅保留指针之前数据,指针之后的数据删除
格式:句柄变量.truncate()
返回:仅保留指针之前数据,指针之后的数据删除

#!/usr/bin/env python
# -*- coding:utf-8 -*-
#truncate() 截断数据,仅保留指针之前数据
#如文件里有:123456789
f = open("h.log", "r+", encoding="utf-8") #打开h.log文件,以r+读写模式,以utf-8编码
print(f.tell()) #查看文件指针
f.seek(5) #将文件指针定位到第5个位置
print(f.tell()) #查看文件指针
f.truncate() #truncate() 截断数据,仅保留指针之前数据,指针之后的数据删除
f.close() #关闭文件
#最后文件里是 12345 后面的被删除了

for 循环文件里的内容,文件句柄是可以被循环的,适合大文件读取好处是节省内存,相当于一行一行的读的,(推荐)
格式:句柄变量 = 打开文件
for 循环
返回:文件里的内容

#!/usr/bin/env python
# -*- coding:utf-8 -*-
#for 文件句柄是可以被循环的,循环文件里的内容,适合大文件读取好处是节省内存,相当于一行一行的读的,
f = open("h.log", "r+", encoding="utf-8") #打开h.log文件,以r+读写模式,以utf-8编码
for i in f:
print(i)
f.close() #关闭文件

with 自动打开文件,对文件操作后,自动关闭文件,不用写关闭文件函数,而且支持同时打开两个文件(推荐)
格式:with open("文件路径","打开模式") as 句柄变量:
返回:句柄变量

#!/usr/bin/env python
# -*- coding:utf-8 -*-
# with 自动打开文件,对文件操作后,自动关闭文件(推荐)
# 格式:with open("文件路径","打开模式") as 句柄变量:
# 返回:句柄变量
with open("h.log", "r+", encoding="utf-8") as f: #自动打开文件,对文件操作后,自动关闭文件
a = f.read() #读出文件内容
print(a) #打印出文件内容

列2 同时打开两个文件,将一个文件的内容写入另外一个文件
假如原始文件很大,所以通过循环文件句柄,读一行写一行到新文件,减少内存使用率

#!/usr/bin/env python
# -*- coding:utf-8 -*-
# 列2 同时打开两个文件,将一个文件的内容写入另外一个文件
# 假如原始文件很大,所以通过循环文件句柄,读一行写一行到新文件,减少内存使用率
with open("1.log", "r", encoding="utf-8") as a, open("2.log", "w", encoding="utf-8") as b: #自动打开文件,对文件操作后,自动关闭文件
for i in a: #循环出原始文件的数据
b.write(i) #每循环出一行原始文件数据,写入新文件里

文件操作2.x源码

class file(object)
def close(self): # real signature unknown; restored from __doc__
关闭文件
"""
close() -> None or (perhaps) an integer. Close the file. Sets data attribute .closed to True. A closed file cannot be used for
further I/O operations. close() may be called more than once without
error. Some kinds of file objects (for example, opened by popen())
may return an exit status upon closing.
""" def fileno(self): # real signature unknown; restored from __doc__
文件描述符
"""
fileno() -> integer "file descriptor". This is needed for lower-level file interfaces, such os.read().
"""
return 0 def flush(self): # real signature unknown; restored from __doc__
刷新文件内部缓冲区
""" flush() -> None. Flush the internal I/O buffer. """
pass def isatty(self): # real signature unknown; restored from __doc__
判断文件是否是同意tty设备
""" isatty() -> true or false. True if the file is connected to a tty device. """
return False def next(self): # real signature unknown; restored from __doc__
获取下一行数据,不存在,则报错
""" x.next() -> the next value, or raise StopIteration """
pass def read(self, size=None): # real signature unknown; restored from __doc__
读取指定字节数据
"""
read([size]) -> read at most size bytes, returned as a string. If the size argument is negative or omitted, read until EOF is reached.
Notice that when in non-blocking mode, less data than what was requested
may be returned, even if no size parameter was given.
"""
pass def readinto(self): # real signature unknown; restored from __doc__
读取到缓冲区,不要用,将被遗弃
""" readinto() -> Undocumented. Don't use this; it may go away. """
pass def readline(self, size=None): # real signature unknown; restored from __doc__
仅读取一行数据
"""
readline([size]) -> next line from the file, as a string. Retain newline. A non-negative size argument limits the maximum
number of bytes to return (an incomplete line may be returned then).
Return an empty string at EOF.
"""
pass def readlines(self, size=None): # real signature unknown; restored from __doc__
读取所有数据,并根据换行保存值列表
"""
readlines([size]) -> list of strings, each a line from the file. Call readline() repeatedly and return a list of the lines so read.
The optional size argument, if given, is an approximate bound on the
total number of bytes in the lines returned.
"""
return [] def seek(self, offset, whence=None): # real signature unknown; restored from __doc__
指定文件中指针位置
"""
seek(offset[, whence]) -> None. Move to new file position. Argument offset is a byte count. Optional argument whence defaults to
(offset from start of file, offset should be >= 0); other values are 1
(move relative to current position, positive or negative), and 2 (move
relative to end of file, usually negative, although many platforms allow
seeking beyond the end of a file). If the file is opened in text mode,
only offsets returned by tell() are legal. Use of other offsets causes
undefined behavior.
Note that not all file objects are seekable.
"""
pass def tell(self): # real signature unknown; restored from __doc__
获取当前指针位置
""" tell() -> current file position, an integer (may be a long integer). """
pass def truncate(self, size=None): # real signature unknown; restored from __doc__
截断数据,仅保留指定之前数据
"""
truncate([size]) -> None. Truncate the file to at most size bytes. Size defaults to the current file position, as returned by tell().
"""
pass def write(self, p_str): # real signature unknown; restored from __doc__
写内容
"""
write(str) -> None. Write string str to file. Note that due to buffering, flush() or close() may be needed before
the file on disk reflects the data written.
"""
pass def writelines(self, sequence_of_strings): # real signature unknown; restored from __doc__
将一个字符串列表写入文件
"""
writelines(sequence_of_strings) -> None. Write the strings to the file. Note that newlines are not added. The sequence can be any iterable object
producing strings. This is equivalent to calling write() for each string.
"""
pass def xreadlines(self): # real signature unknown; restored from __doc__
可用于逐行读取文件,非全部
"""
xreadlines() -> returns self. For backward compatibility. File objects now include the performance
optimizations previously implemented in the xreadlines module.
"""
pass

文件操作3.x源码

class TextIOWrapper(_TextIOBase):
"""
Character and line based layer over a BufferedIOBase object, buffer. encoding gives the name of the encoding that the stream will be
decoded or encoded with. It defaults to locale.getpreferredencoding(False). errors determines the strictness of encoding and decoding (see
help(codecs.Codec) or the documentation for codecs.register) and
defaults to "strict". newline controls how line endings are handled. It can be None, '',
'\n', '\r', and '\r\n'. It works as follows: * On input, if newline is None, universal newlines mode is
enabled. Lines in the input can end in '\n', '\r', or '\r\n', and
these are translated into '\n' before being returned to the
caller. If it is '', universal newline mode is enabled, but line
endings are returned to the caller untranslated. If it has any of
the other legal values, input lines are only terminated by the given
string, and the line ending is returned to the caller untranslated. * On output, if newline is None, any '\n' characters written are
translated to the system default line separator, os.linesep. If
newline is '' or '\n', no translation takes place. If newline is any
of the other legal values, any '\n' characters written are translated
to the given string. If line_buffering is True, a call to flush is implied when a call to
write contains a newline character.
"""
def close(self, *args, **kwargs): # real signature unknown
关闭文件
pass def fileno(self, *args, **kwargs): # real signature unknown
文件描述符
pass def flush(self, *args, **kwargs): # real signature unknown
刷新文件内部缓冲区
pass def isatty(self, *args, **kwargs): # real signature unknown
判断文件是否是同意tty设备
pass def read(self, *args, **kwargs): # real signature unknown
读取指定字节数据
pass def readable(self, *args, **kwargs): # real signature unknown
是否可读
pass def readline(self, *args, **kwargs): # real signature unknown
仅读取一行数据
pass def seek(self, *args, **kwargs): # real signature unknown
指定文件中指针位置
pass def seekable(self, *args, **kwargs): # real signature unknown
指针是否可操作
pass def tell(self, *args, **kwargs): # real signature unknown
获取指针位置
pass def truncate(self, *args, **kwargs): # real signature unknown
截断数据,仅保留指定之前数据
pass def writable(self, *args, **kwargs): # real signature unknown
是否可写
pass def write(self, *args, **kwargs): # real signature unknown
写内容
pass def __getstate__(self, *args, **kwargs): # real signature unknown
pass def __init__(self, *args, **kwargs): # real signature unknown
pass @staticmethod # known case of __new__
def __new__(*args, **kwargs): # real signature unknown
""" Create and return a new object. See help(type) for accurate signature. """
pass def __next__(self, *args, **kwargs): # real signature unknown
""" Implement next(self). """
pass def __repr__(self, *args, **kwargs): # real signature unknown
""" Return repr(self). """
pass buffer = property(lambda self: object(), lambda self, v: None, lambda self: None) # default closed = property(lambda self: object(), lambda self, v: None, lambda self: None) # default encoding = property(lambda self: object(), lambda self, v: None, lambda self: None) # default errors = property(lambda self: object(), lambda self, v: None, lambda self: None) # default line_buffering = property(lambda self: object(), lambda self, v: None, lambda self: None) # default name = property(lambda self: object(), lambda self, v: None, lambda self: None) # default newlines = property(lambda self: object(), lambda self, v: None, lambda self: None) # default _CHUNK_SIZE = property(lambda self: object(), lambda self, v: None, lambda self: None) # default _finalizing = property(lambda self: object(), lambda self, v: None, lambda self: None) # default
 
 
 
 
 
 
 
 
 

第二十六节,Python内置函数的更多相关文章

  1. Python小白学习之路(十六)—【内置函数一】

    将68个内置函数按照其功能分为了10类,分别是: 数学运算(7个) abs()   divmod()  max()  min()  pow()  round()  sum() 类型转换(24个) bo ...

  2. 十九、python内置函数汇总

    '''内置函数abs():取绝对值all():每个元素都为真,才是真any():有一个元素为真即为真bin():十进制转二进制hex():十进制转十六进制int():所有的转成十进制oct():十进制 ...

  3. Python内置函数之匿名(lambda)函数

    Python内置函数之匿名(lambda)函数 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.匿名函数 #!/usr/bin/env python #_*_coding:utf ...

  4. python内置函数大全(分类)

    python内置函数大全 python内建函数 最近一直在看python的document,打算在基础方面重点看一下python的keyword.Build-in Function.Build-in ...

  5. Python补充--Python内置函数清单

    Python内置函数 Python内置(built-in)函数随着python解释器的运行而创建.在Python的程序中,你可以随时调用这些函数,不需要定义.最常见的内置函数是: print(&quo ...

  6. python内置函数

    python内置函数 官方文档:点击 在这里我只列举一些常见的内置函数用法 1.abs()[求数字的绝对值] >>> abs(-13) 13 2.all() 判断所有集合元素都为真的 ...

  7. python 内置函数和函数装饰器

    python内置函数 1.数学相关 abs(x) 取x绝对值 divmode(x,y) 取x除以y的商和余数,常用做分页,返回商和余数组成一个元组 pow(x,y[,z]) 取x的y次方 ,等同于x ...

  8. Python基础篇【第2篇】: Python内置函数(一)

    Python内置函数 lambda lambda表达式相当于函数体为单个return语句的普通函数的匿名函数.请注意,lambda语法并没有使用return关键字.开发者可以在任何可以使用函数引用的位 ...

  9. 那些年,很多人没看懂的Python内置函数

    Python之所以特别的简单就是因为有很多的内置函数是在你的程序"运行之前"就已经帮你运行好了,所以,可以用这个的特性简化很多的步骤.这也是让Python语言变得特别的简单的原因之 ...

  10. python内置函数,匿名函数

    一.匿名函数 匿名函数:为了解决那些功能很简单的需求而设计的一句话函数 def calc(n): return n**n print(calc(10)) #换成匿名函数 calc = lambda n ...

随机推荐

  1. Codeforces Round #346 (Div. 2) B Qualifying Contest

    B. Qualifying Contest 题目链接http://codeforces.com/contest/659/problem/B Description Very soon Berland ...

  2. 寒假学干货之------android开发环境

    1.下载安装jdk(http://www.oracle.com/technetwork/java/javase/downloads/index.html)装se版的就可以了,复制jdk目录路径,之后配 ...

  3. 【CSS】display: inline-block,内联元素

    什么是内联元素? <CSS权威指南>中文字显示:任何不是块级元素的可见元素都是内联元素.其表现的特性是“行布局”形式,这里的“行布局”的意思就是说其表现形式始终以行进行显示.比如,我们设定 ...

  4. UEFI安装Win10

    启动方式: Legency UEFI 分区表类型: MBR 主引导记录 最多4个主分区 最大支持2.1T硬盘 GPT 基于可扩展固件接口(EFI) 分区数不限 NTFS格式最大支持256T硬盘 安装模 ...

  5. hdu1011

    /*比较苦逼的树形DP,慢慢来吧!不着急*/#include <iostream>#include <vector>using namespace std;const int ...

  6. Sass与Compress实战:第八章

    概要:帮助你实现样式表的最佳性能 本章内容: ● 样式表拼接 ● 样式表和资源压缩 ● 减少和并行图片请求的策略 ● 选择器性能和优化策略 1. 测量客户端性能 性能优化的起点和终点都是测量.在第一次 ...

  7. html5存储相关 coookie localstorage session storage

    html5存储 coookie  localstorage   session storage

  8. 通过this获取当前点击选项相关数据

    很多时候jquery只能或者应该回去一个集合.然后通过this获取触发时间的对象及相关属性 this.jq('#needsType').on("click", ".sel ...

  9. uint8与double,二维矩阵显示灰度图

    double型0~1对应uint8型0~255,转换用im2double和im2uint8 如果直接用uint8(double型),则为0~1的uint8型数据,图像全黑. 处理数据过程推荐用doub ...

  10. mac 上面安装mysql-python

    安装过程中一直报错: EnvironmentError: mysql_config not found 最终下面的方式解决: 58down voteaccepted +200 Ok, well, fi ...