函数的做用:函数就是封装某一个功能的;html
例一:
【形式参数:*args,把传入的参数都会以元组的形式打印出来;也会把列表当成一个元素传入到元组里】
def f1(*args): print(args,type(args)) f1(11,22,44,'alex') li = [11,22,'alex','hhh'] f1(li,12)
【实际参数:*,把列表里面的元素传入到元组里面】
f1(*li)
【实际参数:*,把字符串的每个元素传入到元组里面】 li = "name" f1(*li)
例二:
【**args,两个*输出的数据类型为字典,因此传入的参数也必须为两个值】 def f1(**args): print(args,type(args)) f1(n1="alex",n2=18 )
【kk为字典的key,定义的dic为字典kk的value】 dic = {'k1':'v1','k2':'v2'} f1(kk=dic)
【**,把dic字典,以字典形式赋值给args并打印出来】 f1(**dic)
【万能参数,前面是数组,后面是列表】 def f1(*args,**kwargs): print(args) print(kwargs) f1(11,22,33,44,k1='v1',k2='v2') 【python传参数传的是引用当前变量,不是从新赋值一份】 def f1(a1): a1.append(999) li = [11,22,33,44] f1(li) print(li) 【全局变量,变量名用大写】 name = 'alex' def f1(): global name #全局变量,变量名用大写 name = 'freddy' age = 18 print(age,name) def f2(): age = 19 print(age,name) f1() f2()
例一,没有传参:
def sendmail ():
try:
import smtplib
from email.mime.text import MIMEText
from email.utils import formataddr
msg = MIMEText('test mail', 'plain', 'utf-8')
msg['From'] = formataddr(["武沛齐",'wptawy@126.com'])
msg['To'] = formataddr(["走人",'1011464647@qq.com'])
msg['Subject'] = "主题"
server = smtplib.SMTP("smtp.126.com", 25)
server.login("wptawy@126.com", "WW.3945.59")
server.sendmail('wptawy@126.com', ['1011464647@qq.com',], msg.as_string())
server.quit()
except:
return False
else:
return True
res = sendmail()
if res == False:
print("Send mail Fail.")
else:
print("Send mail Seucess.")
例二,带传参:1.收件人 2.邮件内容 3.默认参数:
def sendmail (xxoo,content,xx="OK"):
print(xxoo,content,xx)
try:
import smtplib
from email.mime.text import MIMEText
from email.utils import formataddr
msg = MIMEText(content, 'plain', 'utf-8')
msg['From'] = formataddr(["武沛齐",'wptawy@126.com'])
msg['To'] = formataddr(["走人",'1011464647@qq.com'])
msg['Subject'] = "主题"
server = smtplib.SMTP("smtp.126.com", 25)
server.login("wptawy@126.com", "WW.3945.59")
server.sendmail('wptawy@126.com', [xxoo,], msg.as_string())
server.quit()
except:
return False
else:
return True
res = sendmail('1011464647@qq.com',"sb")
if res == False:
print("Send mail Fail.")
else:
print("Send mail Seucess.")
例3:进阶,手动输入收件人邮件地址;
def sendmail (xxoo,content,xx="OK"):
print(xxoo,content,xx)
try:
import smtplib
from email.mime.text import MIMEText
from email.utils import formataddr
msg = MIMEText(content, 'plain', 'utf-8')
msg['From'] = formataddr(["武沛齐",'wptawy@126.com'])
msg['To'] = formataddr(["走人",'1011464647@qq.com'])
msg['Subject'] = "主题"
server = smtplib.SMTP("smtp.126.com", 25)
server.login("wptawy@126.com", "WW.3945.59")
server.sendmail('wptawy@126.com', [xxoo,], msg.as_string())
server.quit()
except:
return False
else:
return True
while True:
em = input("mail addr:")
result = sendmail(em,"SB")
#传入时间参数,em:收件人地址;SB,是邮件内容;
# result = sendmail(xxoo=em,content="SB")
#指定参数,
if result == 'False':
print('send mail fail.')
else:
print('send mail secuess')
1.这个程序包含一个主程序文件,一个存放帐号密码的文件;python
2.存放密码的文件,帐号和密码的分隔符为“|”json
1 #!/usr/bin/python env 2 #_*_coding:utf-8 _*_ 3 4 def login(username,password): 5 """ 6 用于用户登录 7 :param username: 用户输入的用户名 8 :param password: 用户输入的密码 9 :return: Ture,登录成功;False,登录失败; 10 """ 11 f = open('db','r+') 12 for line in f.readlines(): 13 line = line.split("|") 14 if line[0] == username and line[1] == password: 15 return True 16 return False 17 18 19 def register(username,password): 20 """ 21 用于用户注册 22 :param username: 注册用户名 23 :param password: 注册用户密码 24 :return: 默认None 25 """ 26 f = open('db','a') 27 temp = "\n" + username + "|" + password 28 f.write(temp) 29 f.close() 30 31 32 def main(): 33 t = input("1,login 2.register:") 34 if t == '1': 35 user = input("user:") 36 pwd = input("passwd:") 37 r = login(user,pwd) 38 if r == True: 39 print("login secuess") 40 else: 41 print("login fail") 42 elif t == '2': 43 user = input("user:") 44 pwd = input("passwd:") 45 register(user,pwd) 46 main()
【三元运算,三目运算】 1.正常写法: if 1 == 1: name = "freddy" else: name = "SB" 思路: 1.先判断条件,若是1=1,name就等于freddy, 2.不然,name就等于SB; 2.三目写法: name = "freddy" if 1 == 1 else "SB" print(name) 思路: 1.我想要name等于freddy,想要达到什么条件, 2.不然,就是SB; 【lambda,】 1.正常写法: def t1(a1): return a1 +100 res = t1(10) print(res) 2.lambda写法: f2 = lambda a1: a1 +110 ret = f2(10) print(ret)
语法解析:
1.f2 = lambda #函数名+lambda
2.a1 #形式参数
3. a1 + 100 #函数内执行主体内容
2.1.之lambda + 2个函数: f2 = lambda a1,a2: a1 + a2 +110 ret1 = f2(10,1) print(ret1) 2.2.之lambda + 2个函数 + 默认参数: f2 = lambda a1,a2=2: a1 + a2 +110 ret2 = f2(10) print(ret2)
【abs,绝对值】 n = abs(-1) print(n) 【bool,】 print(bool(1)) 结果:True print(bool(" ")) 结果:True print(bool()) 结果:False print(bool(0)) 结果:False print(bool(None)) 结果:False print(bool([])) 结果:False 【all(),全部为Ture,才为真;】 【能够被迭代,循环的对象】 n = all([1,2,3,4]) print(n) 【any(),只要有一个为真就是真】 n = any([1,[],0,"",None]) print(n) 【bin(),把5转换成2进制】 print(bin(5)) 结果:0b101 #0b表示转成的是2进制
【oct(),把9转换成8进制】 print(oct(9)) 结果:0o11 #0o表示是8进制
【hen(),把15转换成16进制】 print(hex(15)) 结果:0xf #0x表示是16进制
【bytes(),字符串转换成字节】 s = '胜伟' n = bytes(s,encoding="utf-8") print(n) n = bytes(s,encoding="gbk") print(n) 【str(),把字节转换成字符串用str】 nn = str(bytes("胜伟",encoding="utf-8"),encoding="utf-8") print(nn)
【函数默认没有返回值,返回None】
li = [11,22,33,44]
def f1(arg):
arg.append(55)
li = f1(li) #让li从新等于了函数的返回值None
print(li)
结果:None
li = [11,22,33,44]
def f1(arg):
arg.append(55)
return arg #增长了return
li = f1(li)
print(li)
结果:[11, 22, 33, 44, 55]
li = [11,22,33,44]
def f1(arg):
arg.append(55)
f1(li) #直接打印li的值
print(li)
结果:[11, 22, 33, 44, 55]
【bytes:把“唐胜伟”转换成utf-8的格式】
s = "唐胜伟"
ss = bytes(s,encoding='utf-8')
print(ss)
前言:在ASSCII码表中,第65位是大写字母A;
【chr:把ASCII数字转换成字母】
r = chr(65)
print(r)
结果:A
【ord:把大写字母A,转换成ASCII对应的数字】
a = ord("A")
print(a)
结果:65
【compile:就是把字符串编译成python代码】
【exec:执行python代码】
s = "print(123)"
r = compile(s,"<string>","exec")
exec(r)
【eval:把字符串经过evel转成python代码来执行】
s = "8*8"
ret = eval(s)
print(ret)
总结:
exec():能执行python全部的东西; |
eval():只能执行python表达式,而且evel有返回值; |
exec():执行python代码,或者字符串; |
eval():执行表达式,并返回结果; |
【dir():dir():获取python内置方法的功能】
print(dir(list))
help(list)
【divmod:取商和余数,在作分页的时候使用】
r = divmod(100,10)
print(r)
print(r[0])
print(r[1])
r1,r2 = divmod(100,5)
print(r1,r2)
【isinstance:判断对象是不是某个类的实例】
【例:判断对象s是不是str类的实例】
s = "alex"
r = isinstance(s,str)
print(r)
【filter:取出列表中大于22的值】
原理:内部实现机制:li的每一个参数都会执行f2方法,若是条件成立,返回Ture,并把结果赋值给result,返回False不作处理;
例一,不使用filter:
def f1(args):
result = []
for item in args:
if item > 22:
result.append(item)
return result
li = [11,22,33,44,55]
ret = f1(li)
print(ret)
例二,使用filter:
def f2(a):
if a>22:
return True
li = [11,22,33,44,55]
result = filter(f2,li)
#filter(函数,可迭代的对象)
print(list(ret))
【lambda:lambda会内部作返回值,结果是什么就会返回什么】
f1 = lambda a: a > 30
ret = f1(90)
print(ret)
结果:True
【filter+lambda:若是返回True,则把结果赋值给result】
li = [11,22,33,44,55]
result = filter(lambda a: a >33,li)
print(list(result))
结果:[44, 55]
【map:需求,每一个元素加100】
[map语法:map(函数,可迭代的对象(能够for循环的东西))]
方法一,原始方法:
li = [11,22,33,44,55]
def f1(args):
result = []
for i in args:
result.append(100+i)
return result
r = f1(li)
print(r)
方法二,进阶:
li = [11,22,33,44,55]
def f2(a):
return a + 100
result = map(f2,li)
print(list(result))
方法三,map+lambda:
li = [11,22,33,44,55]
result = map(lambda a: a+ 100,li)
print(list(result))
总结:
filter: 函数返回Ture,将元素添加到结果中;
map: 将函数返回值添加到结果中;
【globals():全局变量,locals(),局部变量】
NAME='Freddy'
def show():
a = 123
c = 123
print(locals())
print(globals())
show()
【hash:给传入的对象,转换成hash值,无论你传入的值是多长,hash出来值得长度永远是固定的】
【应用场景:通常都用于成字典的key】
s = 'feawfefeafefafwseesfesfsefwa'
print(hash(s))
【len:】
f = "唐胜伟"
b = len(bytes(f,encoding='utf-8'))
print(len(f))
print(b)
总结:
len:在python3里面,len的结果就是3,python3中用字符来计算的;
在python2中,len的结果就是9,python2中是用字节来计算的;
【max:取出来最大的值】
r = max([11,22,88,55])
print(r)
【min:取出来最小的值】
r = min([11,22,88,55])
print(r)
【sum:求和】
r = sum([11,22,88,55])
print(r)
【reversed:反转显示结果】
li = [11,22,44,33]
r = reversed(li)
print(list(r))
【round:四舍五入】
r = (1.8)
print(r)
结果:2
r = round(1.4)
print(r)
结果:1
【zip:取值方法】
l1 = ['freddy',11,22,33]
l2 = ['is',11,22,33]
l3 = ['sb',11,22,33]
tem = zip(l1,l2,l3)
print(list(tem))
结果:[('freddy', 'is', 'sb'), (11, 11, 11), (22, 22, 22), (33, 33, 33)]
例二:
l1 = ['freddy',11,22,33]
l2 = ['is',11,22,33]
l3 = ['sb',11,22,33]
tem = zip(l1,l2,l3)
* 使用zip进行格式化输出;
tmp = list(tem)[0]
print(tmp)
('freddy', 'is', 'sb')
* 取出序列化的第一列
ret = ' '.join(tmp)
print(ret)
结果:
freddy is sb
【r,只读】 f =open('db','r') 【w,清空原来db文件,而后再写入新内容】 f =open('db','w') 【x,文件存在报错,不存在,建立并写内容】 f =open('db','x') 【a,追加内容】 f =open('db','a')
【ab,追加写入;bytes,字节编码写入至文件内】
f = open("db",'ab')
f.write(bytes("胜伟",encoding="utf-8"))
f.close()
【读文件方法:1.utf-8。2.GBK。】
f = open('db','r',encoding='utf-8') #若是文件是以'utf-8'方式保存的,这里就要写一个'utf-8';
f = open('db','r',encoding='GBK') #若是文件是以gbk方式保存的,这里就要写一个GBK;
res = f.read()
print(res)
f.close()
【直接以二进制方式打开文件,优势:1.跨平台。2.快。】
f = open('db','rb')
data = f.read()
print(data,type(data))
【若是想以二进制的形式写入文件,写入的内容也必须转成二进制格式】
f = open('db','xb')
f.write(bytes('唐胜伟',encoding='utf-8'))
f.close()
【加b,以二进制,字节方式读】
f = open('db','rb')
res = f.read()
f.close()
print(res,type(res))
结果:b'\xe5\x94\x90\xe8\x83\x9c\xe4\xbc\x9f' <class 'bytes'>
【以字符串的方式读】
f = open('db','r',encoding='utf-8')
res = f.read()
f.close()
print(res,type(res))
结果:唐胜伟 <class 'str'>
【seek(),永远找的是字节指针位置,一个字母一个字节,一个汉字,若是是utf-8的格式,是三个字节】
f = open('db','r+',encoding="utf-8")
data=f.read(1) #f.read(1):若是以r的方式打开,读取就是一个字符指针位置;若是以rb的方式打开,读取就是一个字节指针位置
print(data)
f.seek(1) #seek(),调整指针的位置,seek的时候,seek的永远是字节的指针位置
f.write("777")
f.close()
【tell:获取当前指针的位置,单位永远是字节】
f = open('db','r+',encoding="utf-8")
data=f.read(1)
print(f.tell()) #f.tell():获取当前指针的位置,结果是:3,由于一个汉字(字符)占3位;
f.seek(f.tell()) #在tell获取的位置开始写内容,向后覆盖;
f.write("777")
f.close()
【读出来的文件类型是,字符串】
f=open('db','r',)
data = f.read()
print(data,type(data))
结果:<class 'str'>
f=open('db','r',encoding='utf-8')
data = f.read()
print(data,type(data))
结果:<class 'str'>
【rb,以字节方式读,读取类型是 字节】
f=open('db','rb',)
data = f.read()
print(data,type(data))
结果:<class 'bytes'>
【有b,按照字节读取;无b,按照字符读取】
f = open('db','r+',encoding='utf-8')
【tell(),获取当前指针位置;
seek(1) 跳转到指定指针位置】
data = f.read(1) #tell当前指针所在的位置(字节)
print(f.tell()) #调整当前指针的位置(字节)
f.seek(f.tell()) #当前指针位置开始向后覆盖
f.write('777') # write() 写数据,有b,写字节,没b,写字符;
write()
【flush,把缓冲区内容写入硬盘】
文件1:
f = open('db','a')
f.write("123")
f.flush()
input("str:")
文件2:
f =open('db','r+')
ret = f.read()
print(ret)
【readable,判断是否可写】
f = open('db','w')
ret = f.readable()
print(ret)
【readline,一行一行读,避免读取数据过大】
f = open('db','r')
f.readline()
f.readline()
【truncate,截断数据,把指针位置后的数据清空】
f = open('db','r+',encoding='utf-8')
f.seek(3)
f.truncate()
f.close()
【一行,一行的读这个文件】
f = open('db','r+',encoding="utf-8")
for line in f:
print(line)
【with,优势:不用手动去关闭文件,代码块的代码执行完后会自动关闭文件(f.close)】
思路一:
把f1文件里面的内容所有写入到f2:
with open('db1','r',encoding='utf-8') as f1,open('db2','w',encoding='utf-8') as f2:
for line in f1:
f2.write(line)
【把db1的前10行内容写入到db2文件中】
with open('db','r',encoding='utf-8') as f1,open('db1','w',encoding='utf-8') as f2:
count = 0
for line in f1:
count +=1
if count <= 10:
f2.write(line)
else:
break
思路二:
【把db1文件中的freddy,替换成st】
with open('db1','r',encoding='utf-8') as f1,open('db2','w',encoding="utf-8") as f2:
for line in f1:
new_str = line.replace("freddy",'st')
f2.write(new_str)
【例1:生成6位字母验证码】 import random li = [] for i in range(6): temp = random.randrange(65,91) c = chr(temp) li.append(c)
例二验证码,程序带入: 【join的时候元素必须都是字符串】 result = "".join(li) print(result)
【例二:生成6位,包含两个数字的验证码】 import random li = [] for i in range(6): r = random.randrange(0,5) print(r) if r == 2 or r == 4: num = random.randrange(0,10) li.append(str(num)) ##转换成字符串类型,不然不能join else: temp = random.randrange(65,91) c = chr(temp) li.append(c) result = "".join(li) print(result)
【语法技巧】
if True:
print('aa')
tt = True
if tt:
print('aa')
【列表格式的字符串】 s = "[11,22,33,44,55]" print(s,type(s)) 结果:<class 'str'> 【json:数据序列化,跨平台传输数据】 import json s = "[11,22,33,44,55]" n = json.loads(s) print(n,type(n)) 结果:<class 'list'> #json:将指定格式的字符串,转换成python的基本数据类型, #注意:字符串形式的字典{"k1":"v1"}的内部字符串必须是双引号; 【json:格式化输出】 import json r = input("input dic:") dic = json.loads(r) bk = dic['backend'] rd = "server %s %s weight %d maxconn %d"%(dic['record']['server'], dic['record']['server'], dic['record']['weight'], dic['record']['maxconn']) print(bk) print(rd) 输入内容:{"backend": "test.oldboy.org","record":{"server": "100.1.7.9","weight": 20,"maxconn": 30}}