一,函数的定义
1,函数mylen叫做函数名
#函数名
#必须由字母下划线数字组成,不能是关键字,不能是数字开头
#函数名还是要有一定的意义能够简单说明函数的功能
2,def是关键字 (define)
3,():必须写
4,函数体内尽量写注释,方便查看代码
5,函数的调用:函数名+括号
1 #!/usr/bin/env python
2 #_*_coding:utf-8_*_
3
4 def mylen(): #函数名
5 '''
6 计算字符串长度的函数 这里写的是注释,方便查看代码
7 '''
8 s = 'hello world'
9 length = 0
10 for i in s:
11 length += 1
12 return length #函数的返回值
13 leng = mylen() #函数的调用
14 print(leng)
二,函数的返回值 return
1,函数返回值可以是任意的数据类型
2,如果有返回值:必须要用变量接收才会有效果
1 #!/usr/bin/env python
2 #_*_coding:utf-8_*_
3
4 def func():
5 b = [1,2,3]
6 return b #可以是任何数据类型
7 ret = func() #有返回值,就需要用变量来接收
8 print(ret)
3,函数可以没有返回值,默认返回给None
函数的返回值为None有三种情况
1.不写返回值
2.只写一个return
3.return None (几乎不用)
4,return的作用:结束一个函数的执行
5,函数的返回值不为None,有返回值
返回一个值(一个变量)
返回多个值(多个变量),多个值之间用逗号区分
接收:可以用一个变量接收,以元组的形式返回
也可以用多个变量接收,返回几个就用几个变量去接收 相当于解压式接收
1 #!/usr/bin/env python
2 #_*_coding:utf-8_*_
3
4 def func6():
5 '''返回一个值'''
6 a =123
7 return a
8
9 def func7():
10 '''返回多个值'''
11 a = 123
12 b = 'abc'
13 return a,b
14
15 ret = func7()
16 print(ret)
17 m,n,k = func7()
三,函数的参数
实参:函数调用的时候传入的参数
形参:函数定义的时候括号内的参数
参数可以是任意的数据类型,可以传送0个或者多个参数
1 #!/usr/bin/env python
2 #_*_coding:utf-8_*_
3
4 def mylen(s): #参数接收:形式参数,形参
5 '''
6 计算字符串长度的函数 ——函数的功能
7 参数s:接收要计算的字符串 ——参数的信息
8 return:要计算的字符串长度 ——返回值的信息
9 '''
10 length = 0
11 for i in s:
12 length += 1
13 return length
14 length = mylen('hello world') #参数传入:实际参数,实参
15 print(length)
调用时传参数(实参)
实参,遵循 位置参数--关键字参数
*按照位置参数传参:按顺序定义参数
1 #!/usr/bin/env python
2 #_*_coding:utf-8_*_
3
4 def my_max(a,b): #定义:位置参数
5 '''返回两个值之间的最大值'''
6 print(a,b)
7 if a > b:
8 return a
9 else:
10 return b
11 print(my_max(10,20))
12 print(my_max(30,20))
*按照关键字参数传参:可以不按顺序传参数
1 #!/usr/bin/env python
2 #_*_coding:utf-8_*_
3
4 def my_max(a,b): #定义:关键字参数
5 '''返回两个值之间的最大值'''
6 print(a,b)
7 if a > b:
8 return a
9 else:
10 return b
11 print(my_max(b = 10,a = 20))
定义时候参数(形参)
形参,遵循 位置参数--默认参数
*默认参数
*不要设置可变类型的默认参数
*默认参数可以不传,不传用的是默认值,传参数的话需要用关键字传参,才可以覆盖默认值
*默认值是在定义函数的时候就已经确定了的
1 #!/usr/bin/env python
2 #_*_coding:utf-8_*_
3
4 def stu_info(name,sex = 'male'): #默认参数,有一个默认值
5 print('name:%s,sex:%s'%(name,sex))
6 stu_info('alex') #默认参数可以不传值
7 stu_info('egon','female') #如果传值了,覆盖默认值
关于默认参数流程
1 #!/usr/bin/env python
2 #_*_coding:utf-8_*_
3
4 #关于默认参数流程
5 s = 'male'
6 def stu_info(name,sex=s): #默认参数,有一个默认值
7 print('name:%s,sex:%s'%(name,sex))
8 s = 'female' #不影响定义时sex的值
9 print(stu_info("李淑旗"))
10 #打印出来的就是male 因为开始sex=x=male,然后s是新开辟的一个空间存储female
不要这是可变类型数据为默认参数
1 #!/usr/bin/env python
2 #_*_coding:utf-8_*_
3
4 #不要设置可变数据类型为默认参数
5 b = []
6 def func(a = []):
7 a.append(1)
8 print(a)
9 # func()....打印下去你会发现这个[]列表一直在追加
动态参数
*args 接收的是实参,位置参数,将转化成元祖返回
1 #!/usr/bin/env python
2 #_*_coding:utf-8_*_
3
4 #*args #按位置传参数
5 def func(a,b,*c): #*c接收的是5,5,5,5并且输出一个元祖包含这个4个5 *args代表把散列的元素拼成元组
6 my_sum = a+b
7 for i in c:
8 my_sum += i
9 return my_sum
10 print(func(3,2,5,5,5,5))
*kwargs 接收的是实参,关键字参数,将转化成字典返回
1 #!/usr/bin/env python
2 #_*_coding:utf-8_*_
3
4 #**kwargs #按照关键字传参数
5 def fun(a,b,**kwargs):
6 print(a,b,kwargs)
7 fun(a = 10,b = 20,cccc= 30,dddd = 50)
行参,位置顺序
1 #!/usr/bin/env python
2 #_*_coding:utf-8_*_
3
4 #形式参数括号里面的位置顺序
5 def f(a,b,*args,defult=6,**kwargs):
6 #位置参数,*args,默认参数,**kwargs
7 print(a,b,args,defult)
8 #传参数的时候:必须先按照位置传参数,再按照关键字传参数
9 f(1,2,7,8,defult=10)
传参时候,有时候是可变得数据类型,下面是2个方法可以将不同类型数据类型打散
1 #!/usr/bin/env python
2 #_*_coding:utf-8_*_
3
4 #在传参的时候,针对列表,元祖的话,有个*t参数,避免手动传参
5 def fun2(*args):#*args代表把散列的元素拼成元组
6 print(args)
7 t = (1,2,3,4)
8 l = [1,2,3,4]
9 # fun2(t[0],t[1],t[2],t[3])
10 fun2(*t) #*代表把一个元组、列表拆了
11 fun2(*l) #*代表把一个元组、列表拆了
12
13 #针对字典有个**d参数,避免手动传参
14 def fun3(**kwargs):#*args代表把按关键字传来的参数拼成字典
15 print(kwargs)
16 fun3(a = 10, b = 20)
17 d = {'a': 10, 'b': 20}
18 fun3(**d) #*代表把一个字典拆了
传参时候传递的是引用
# 我们之前学过字符串的format方法
msg = "{0},{1}"
print(msg.format("joker","11"))
print(msg.format(*["joker","11"]))
msg = "{name},{age}"
print(msg.format(name="joker",age="11"))
print(msg.format(**{"name":"joker","age":"11"}))
# 传递数据类型时候,其实传递的是引用
l = [1,2,3,4]
def f1(a1):
a1.append(999)
f1(l)
print(l) # [1, 2, 3, 4, 999]
# 全局变量,通常全部大写
name = [1,2,3,4]
def f1():
global name # 直接修改
name = [111]
return
f1()
print(name) # [111]
name = [1,2,3,4]
def f1():
name.append(5) # 局部不能给全局重新赋值
return
f1()
print(name) # [1, 2, 3, 4, 5]
相同函数名执行过程
# !/usr/bin/env python
# _*_coding:utf-8_*_
# Author:Joker
def f1(a1,a2): # 1
return a1 + a2
def f1(a3,a4): # 2
return a3 * a4 # 4
ret = f1(8,8) # 3 #5
print(ret) # 6
# 开始f1的空间包含指向为a1 + a2,后来变为了a3 * a4,在实参传递的时候,你也会发现给的是a3,a4赋值
通过126发送小邮件程序
# !/usr/bin/env python
# _*_coding:utf-8_*_
# Author:Joker
def sendmail():
import smtplib
from email.mime.text import MIMEText
from email.utils import formataddr
msg = MIMEText('我正在通过PY给你发送邮件,别再睡了。','plain','utf-8') # 创建一个文本类型
msg['From'] = formataddr(['joker','jokerbj@126.com']) # 二元祖,发件人,发件地址
msg['Subject'] = "亲爱的POPPY君"
server = smtplib.SMTP('smtp.126.com',25)
server.login('jokerbj@126.com','授权登录密码') # SMTP第三方授权登录密码
server.sendmail('jokerbj@126.com',['对方邮件地址@qq.com',],msg.as_string())
server.quit()
return 1
ret = sendmail()
if ret:
print('email send success!')