python开三次方函数_Python 基础3 函数function

1、函数 function

什么是函数:函数是可以重复执行的语句块,可以重复调用;

作用:

用于封装语句,提高代码的重用性

用于定义(创建)用户级别的函数

语法:

def 函数名(形参列表):

语句块

说明:

1、函数的名字就是语句块的名称;

2、函数名的命名规则与变量名相同(函数名必须是标识符(字母或下划线开头));

3、函数名是一个变量;

4、函数有自己的名字空间,在函数外部不可以访问函数内部的变量,在函数内部可以访问函数外部的变量,要让函数处理外部数据需要用参数给函数传入一些数据;

5、参数列表 可以为空;

6、语句部分不能为空,如果为空需要用pass语句填充;

2、函数调用:

函数名(实际调用传递参数,简称实参)

说明:

函数调用是一个表达式;

如果没有return语句,函数执行完毕后返回None对象;

如果函数需要返回其它的对象需要用到return语句;

3、函数说明:

函数外部无法访问函数内部的局部变量;

函数内部可以访问函数外部的变量,但不能修改函数外部变量的绑定关系;

示例:

x=0defmyadd(a,b):

x= a +bprint(x) #结果为300

myadd(100, 200)print(x) #结果为0

4、return 语句:

语法:

return [表达式]

注:[] 代表内容可省略

作用: 结束函数的执行,返回到调用函数位置!

只用于函数中,结束当前的函数的执行,返回到调用该函数的位置 ,同时返回表达式的引用关系;

说明:

1、return 语句后跟的表达式可以省略,省略后相当于return None;

2、如果函数内没有return语句,则函数执行完最后一条语句后返回None(相当于在最后加了一条return None语句);

示例:defsay_hello():print('1')print('2')return

print('3')

say_hello()

say_hello()#注意:这里函数调用返回的结果是1 ,2, 1,2;函数内看到return语句表示结束当前的函数执行,返回调用该函数位置。

5、函数的参数传递:

传递方式:

位置传参

序列传参

关键字传参

字典关键字传参

5.1、位置传参:

实际传递参数(以下简称实参)与形式参数(形参)的对应关系按位置来依次对应;

示例:

position_give_args.pydefmyfun(a, b, c):print('a=', a)print('b=', b)print('c=', c)

myfun(1, 2, 3)

5.2、序列传参:(归属位置传参)

序列传参是指在函数调用过程中用“*”将序列拆解后按位置进行传递的传参方式;

示例:sequence_give_args.pydefmyfun(a, b, c):print('a=', a)print('b=', b)print('c=', c)

s= "ABC"L= [4,5,6]

t= (1.1, 2.2, 3,3)

myfun(*s) #字符串序列传参

myfun(*L) #列表序列传参

myfun(*t) #元组序列传参

5.3、关键字传参:

关键字传参是指传参时,按着形参的“名称”给形参赋值,实参和形参按名称进行匹配;

示例:#keyword_give_args.py

defmyfun(a, b, c):print('a=', a)print('b=', b)print('c=', c)

myfun(b=2, c=3, a=1)

5.4、字典关键字传参:(归属关键字传参)

是指实参为字典,将字典用“**” 拆解后进行关键字传参的传参方式;

示例:dict_keyword_give_args.pydefmyfun(a, b, c):print('a=', a)print('b=', b)print('c=', c)

d= {'a':111, 'c':333, 'b':222}

myfun(**d)

说明:字典的键名和形参名必须一致;

字典的键名必须为字符串(且必须为标识符的规则);

字典的键名要在形参中存在;

5.5、函数的综合传参:

函数的传参方式在能确定形参 能唯一匹配到对应实参的情况下可以任意组合;

要求:

位置传参在前,关键字传参在后!

示例:com_give_args.pydefmyfun(a, b, c):print('a=', a)print('b=', b)print('c=', c)

myfun(1,c = 3, b = 2)

myfun(100, *[200, 300])

myfun(*"AB", 300)

myfun(*"AB", **{'c':300})

6、函数的缺省参数

语法:

def 函数名(形参名1=默认实参1,形参名2=默认实参2,....)

说明:

缺省参数必须自右至左依次存在,如果一个参数 有缺省参数,则其右侧的所有参数都必须有缺省参数;

def fa(a=1, b, c=3):#是错误的

缺省参数可以有0个或多个,甚至全部都是缺省参数;

示例:#defualt_args.py

def info(name, age=1,address="未填写"):print(name,'今年',age,'岁,住在:', address)

info('小李')

info('小李', age=20)

info('小李', age=20,address='重庆')

info('小李', 33, '重庆市大竹林')

7、函数形参的定义方式:

位置形参

星号元组形参

命名关键字形参

双星号字典形参

7.1、位置形参:

语法:

def 函数名(形参名1,形参名2,...):

语句块

7.2、星号元组形参:

语法:

def 函数名(*元组形参名):

语句块

作用:收集多余位置传参

print("示例见:#star_tuple_args.py")#星号元组形参

def fb(*args):'''args绑定一个元组'''

print('实参个数是:', len(args))print("args:", args)

fb()

fb(1,2,3,4)

7.3、命名关键字形参:

语法:

def 函数名(*,命名关键字形参):

语句块

def 函数名(*args,命名关键字形参):

语句块

作用: 强制*后所有的传参都必须用关键字传参

示例:#keywords_args.py

def fa(a, b, *, c, d):'''强制c,d必须用关键字传参'''

print(a, b, c, d)#fa(1,2,3,4) #错的

fa(1,2, c=3, d=4)

fa(1,2, d=400, c=300)def fb(a, b, *args, c, d):'''强制c,d必须用关键字传参'''

print(a, b, args,c, d)#fb(1,2,3,4,5,d=400,c=200) #1 2 (3, 4, 5) 200 400

fb(1,2,3,4,5,**{'d':400,'c':300}) #1 2 (3, 4, 5) 300 400

7.4、双星号字典形参:

语法:

def 函数名(**字典形参名):

语句

作用: 收集多余的关键字传参

示例:#double_start_keyword_args.py

def fa(**kwargs):'''kwargs绑定字典'''

print("多余的关键字传参的个数是:", len(kwargs))print("kwargs =", kwargs)#fa(a=10, b=20, c=30) #kwargs = {'a': 10, 'b': 20, 'c': 30}

def fb(*args, a, **kwargs):print(args, a, kwargs)

fb(1,2,3,4,5, a=10, b=30, c=40) #(1, 2, 3, 4, 5) 10 {'b': 30, 'c': 40}

函数的参数说明:

位置形参,星号元组形参,命名关键字形参,双星号字典形参,缺省参数可以混合使用;

函数参数自左至 的顺序依次为:

位置形参

星号元组形参

命名关键字形参

双星号字典形参

示例:def fn(a, b, *args, c, d, **kwargs):print(a, b, args, c, d, kwargs)

fn(1,2,3,4, c=100, d=200, e=300, f=400) #1 2 (3, 4) 100 200 {'e': 300, 'f': 400}

#1.思考题#查看>>>help(print)#猜想print函数的参数列表是如何定义的?

def myprint(*args, sep=' ', end='\n')

L= [str(x) for x in args] #把所有元组元素转为字符串列表

s = sep.join(L) #把列表中字符串以sep变量字符串连接成字符串,赋值给s

s +=endprint(s, end='')#方法二

def pyprint1(*args, sep=' ', end='\n'):print(*args, sep=sep, end=end) #直接调用print函数,传参#myprint(1,2,3,4,5)

myprint('hello','world',sep='#')

myprint(1,2,3,4, sep=':', end='我是结尾\n')#2..思考题写一个myrange函数,参数可以传入1-3个,实际意义同range函数规则相同,此函数返回符合range(。。。)函数规则的列表

def myrange(start,stop=None,step=1):

r_lst=[] #即将返回的列表

#调整三个形参的值

if stop isNone:

stop=start

start=0if step >0:while start

r_lst.append(start)#把当前数加入到列表中

start += step #让start向后移动,准备下次操作

else: #当步长小于0的情况,倒序

for x inrange(start,stop,step):

r_lst.append(x)returnr_lst#L = myrange(4)print(L) #[0,1,2,3]

L = myrange(4,6)print(L) #[4,5]

L = myrange(1,10,3)print(L) #[1,4,7]

L = myrange(10,1,-2)print(L)

print('1.题---------------')#练习#1. 算出 100-999之间的水仙花数(narcissistic number)#水仙花数是指百位的3次方,加上十位的3次方,加上个位的3次方等于原数的整数#例如 153 = 1 ** 3 + 5 ** 3 + 3 ** 3#建议先写一个函数is_narcissistic(n)来判断n是否为水仙花数,如果是返回True,否则返回False#再调用些函数进行判断

defis_narcissistic(n):

L=list(str(n))

jisuan= int(L[0]) ** 3 + int(L[1]) ** 3 + int(L[2]) ** 3

if jisuan ==n:returnTrueelse:returnFalse#

#n = int(input('请输入三位整数:'))#print('判断', n, '是否为水仙花数,结果', is_narcissistic(n))

print('水仙花数为:')for x in range(100,1000):ifis_narcissistic(x):print(x, end=' ')else:print()print('\n\n')print('2.题---------------')#2. 求100以内的全部素数(质数)#2,3,5,7,11..........#建议用函数来做#两个函数#def is_prime(x):#判断 x是否是素数,是返回true ,否返回False#def print_primes(n):#此函数打印小于n的全部素数#print_primes(100)开始打印

#定义判断质数函数,是返回true,不是返回false

defis_prime(x):if x < 2:returnFalsefor i in range(2, x):if x % i ==0:returnFalsereturnTruedefprint_primes(n):print('小于',n,'的全部素数:',end=' ')for i inrange(n):#调用函数判断i是否是素数

ifis_prime(i):print(i, end=' ')else:print()

print_primes(100)print('\n\n')#3.将上次的student_info.py改写为两个函数:#1) def input_student():#2) def output_student(L):#主程序调用:#docs = input_student()#output_student(docs)#print(请再添加几个学生信息..)#docs += input_student()#print(添加之后的学生信息是)#output_student(docs)

definput_student():

lst= [] #定义空列表

#定义循环读入学生信息

whileTrue:

student_name= input('请输入学生姓名:')#判断输入学生姓名为空结束输入

if notstudent_name:breakstudent_age= int(input('请输入学生年龄:'))

student_score= int(input('请输入学生成绩:'))

student_dict= {} #定义新空字典,用于存放学生信息

student_dict['name'] =student_name

student_dict['age'] =student_age

student_dict['score'] =student_score#将字典使用append方法,存入到L列表中,注意这此处未改变L全局变量的绑定关系

lst.append(student_dict)#print('打印列表lst信息: ',lst)

returnlstdefoutput_student(L):#显示学生信息列标头

print('+','-' * 20,'+','-' * 10,'+','-' * 12, '+')print('|', 'name'.center(20),'|','age'.center(10), '|', 'score'.center(12), '|')print('+','-' * 20,'+','-' * 10,'+','-' * 12, '+')#此处打印所有学生的信息

#把学生的数据取出来,用k绑定对应的字典

for k inL:#将姓名格式变成20宽度居中的字符串

center_name = k['name'].center(22)#先将年龄转换为字符串

str_age = str(k['age'])

center_age= str_age.center(12)

str_score= str(k['score'])

center_score= str_score.center(14)#print('|',center_name, '|', center_age, '|', center_score, '|')

line = "|%s|%s|%s|" %(center_name, center_age, center_score)print(line)print('+','-' * 20,'+','-' * 10,'+','-' * 12, '+')defmain():

docs=input_student()

output_student(docs)print('请再添加几个学生信息..')

docs+=input_student()print('添加之后的学生信息是')

output_student(docs)

main

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值