python语言输出函数,python语言输出函数帮助

Python其实很简单 第十二章 函数与变量的作用域

在前面已经多次提到函数这个概念,之所以没有解释什么是函数,是因为程序中的函数和数学中的函数差不多,如input()、range()等都是函数,这些都是Python的标准函数,直接使用就可以了。根据需要,用户也可以自定义函数。

专注于为中小企业提供成都做网站、网站建设服务,电脑端+手机端+微信端的三站合一,更高效的管理,为中小企业定海免费做网站提供优质的服务。我们立足成都,凝聚了一批互联网行业人才,有力地推动了上千企业的稳健成长,帮助中小企业通过网站建设实现规模扩充和转变。

12.1 函数

函数的结构:

def 函数名(参数):

函数体

return 返回值

例如:数学中的函数f(x)=2x+5在Python中可以定义如下:

def f(x):

y=2*x+5

return(y)

如果x取值为3,可以使用如下语句调用函数:

f(3)

下面给出完整的程序代码:

def f(x):

y=2*x+5

return(y)

res=f(3)

print(res)

运行结果:11

如上例中的x是函数f(x)的参数,有时也被称为形式参数(简称形参),在函数被调用时,x被具体的值3替换y就是函数的返回值,这个值3也被称为实际参数(简称实参)。

上例中的y是函数f(x)的返回值。并不是所有的函数都有参数和返回值。如下面的函数:

def func():

print('此为无参数传递、无返回值的函数')

func()

输出结果:此为无参数传递、无返回值的函数

可以看出,该函数func()无参数,故调用时不用赋给参数值。

函数也可以有多个参数,如f(x,y)=x²+y²,可用Python语言定义如下:

def f(x,y):

z=x**2+y**2

return z

print(f(2,3)) #调用函数f(x,y)

输出结果:13

也可以通过直接给参数列表中的参数赋值的方法,为参数添加默认值,如果用户赋予参数值,则按照用户赋值执行,否则使用默认值。例如:

def f(x,y=3):

z=x**2+y**2

return z

若调用时参数列表为(2,1),即x赋值为2,y赋值为1:

print(f(2,1))

输出结果为:5

若调用时参数列表为(2),即x赋值为2,y赋值省缺,则y使用默认值:

print(f(2))

输出结果为:13

回调函数,又称函数回调,是将函数作为另一函数的参数。

例如:

def func(fun,m,n):

fun(m,n)

def f_add(m,n):

print('m+n=',m+n)

def f_mult(m,n):

print('m*n=',m*n)

func(f_add,2,3)

func(f_mult,2,3)

输出结果:

m+n= 5

m*n= 6

在f_add(m,n)和f_mult(m,n)被定义前,func(fun,m,n)中的fun(m,n)就已经调用了这两个函数,即“先调用后定义”,这也是回调函数的特点。

如果无法预知参数的个数,可以在参数前面加上*号,这种参数实际上对应元组类型。譬如,参会的人数事先不能确定,只能根据与会人员名单输入:

def func(*names):

print('今天与会人员有:')

for name in names:

print(name)

func('张小兵','陈晓梅','李大海','王长江')

运行后,输出结果为:

今天与会人员有:

张小兵

陈晓梅

李大海

王长江

参数为字典类型,需要在参数前面加上**号。

def func(**kwargs):

for i in kwargs:

print(i,kwargs[i])

func(a='a1',b='b1',c='c1')

输出结果为:

a a1

b b1

c c1

一个有趣的实例:

def func(x,y,z,*args,**kwargs):

print(x,y,z)

print(args)

print(kwargs)

func('a','b','c','Python','is easy',py='python',j='java',ph='php')

输出结果:

a b c # 前三个实参赋给前三个形参

('Python', 'is easy') # *args接收元组数据

{'py': 'python', 'j': 'java', 'ph': 'php'} # **kwargs接收字典数据

12.2 变量的作用域

变量的作用域即变量的有效范围,可分为全局变量和局部变量。

局部变量

在函数中定义的变量就是局部变量,局部变量的作用域仅限于函数内部使用。

全局变量

在主程序中定义的变量就是全局变量,但在函数中用关键字global修饰的变量也可以当做全局变量来使用。

全局变量的作用域是整个程序,也就是说,全局变量可以在整个程序中可以访问。

下面通过实例去讨论:

程序1:

a=1 # a为全局变量

def a_add():

print('a的初值:',a) # 在函数中读取a的值

a_add() # 调用函数a_add()

a+=1 # 主程序语句,a增加1

print('a现在的值是:',a) # 主程序语句,读取a的值

运行结果:

a的初值: 1

a现在的值是: 2

这个结果和我们想象的一样,全局变量a既可以在主程序中读取,也可以在子程序(函数)中读取。

程序2:

a=1

def a_add():

a+=1

print('a的初值:',a)

a_add()

print('a现在的值是:',a)

运行程序1时出现如下错误提示:

UnboundLocalError: local variable 'a' referenced before assignment

意思是:局部变量'a'在赋值之前被引用。

从语法上来讲,该程序没有错误。首先定义了一个全局变量a并赋值为1,又定义了一个函数a_add(),函数内的语句a+=1就是出错的根源,虽然我们的初衷是想让全局变量a的值增加1,但从错误提示看,这个语句中的a并不是全局变量,而是局部变量。看来,在函数中读取全局变量的值是没有问题的(在程序1中已经得到了验证),但要在函数中改变全局变量的值是不行的(在程序2的错误提示a+=1中的a 是局部变量,而非全局变量)。

怎样解决这个问题?

程序3:

a=1

def a_add(x):

x+=1

return x

print('a的初值:',a)

a=a_add(a)

print('a现在的值是:',a)

运行结果:

a的初值: 1

a现在的值是: 2

结果的确是正确的,但在函数a_add(x)中没有调用变量a(没有出现变量a)。

程序4:

a=1

def a_add(a):

a+=1

return a

print('a的初值:',a)

a=a_add(a)

print('a现在的值是:',a)

运行结果:

a的初值: 1

a现在的值是: 2

对比程序4和程序3不难发现,其实程序4只是简单的把函数的参数x变成了a,这个a的实质和程序3中的x还是一样的。这进一步证实,函数中的a是局部变量,与主程序的全局变量a有着本质的区别。

程序5:

a=1

def a_add():

global a

a+=1

print('a的初值:',a)

a_add()

print('a现在的值是:',a)

运行结果:

a的初值: 1

a现在的值是: 2

程序5和程序2相比较,仅仅是在函数中添加了一个定义“global a”,此时的局部变量a就可以当做全局变量使用,由于它和全局变量a同名,自然也就不用区分a究竟是全局变量还是局部变量了,在主程序和该函数内都可以访问、修改变量a的值了。

虽然使用global可使变量使用起来非常方便,但也容易引起混淆,故在使用过程中还是谨慎为好。

12.3 函数的递归与嵌套

递归,就是函数调用它自身。递归必须设置停止条件,否则函数将无法终止,形成死循环。

以计算阶乘为例:

def func(n):

if n==1:

return 1

else:

return n*func(n-1) #func( )调用func( )

print(func(5))

运行结果为:120

嵌套,指在函数中调用另外的函数。这是程序中常见的一种结构,在此不再赘述。

匿名函数

Python中可以在参数前加上关键字lambda定义一个匿名函数,这样的函数一般都属于“一次性”的。

例如:

程序1:这是一个常规的函数定义和调用。

def f_add(x,y):

return x+y

print(f_add(2,3))

输出结果:5

程序2:使用lambda定义匿名函数。

f_add=lambda x,y:x+y

print(f_add(2,3))

输出结果:5

从上面的代码可以看出,使用lambda仅仅减少了一行代码。f_add=lambda x,y:x+y中的f_add不是变量名,而是函数名。程序1和程序2的print( )语句中的参数都是一样的——调用函数f_add( )。所以,匿名函数并没有太多的优点。

在不同操作系统下python语言均不需要设置头文件

不需要。在C语言中需要包含头文件、创建主函数、使用头文件中的printf函数来进行输出。但在Python语言中无需包含头文件,就可以直接使用Python语言中的输出函数print来输出。Python由荷兰数学和计算机科学研究学会的GuidovanRossum于1990年代初设计,作为一门叫做ABC语言的替代品。

python中print函数的用法

python中print函数的用法是:

第一种方法:一个萝卜一个坑,下面的代码中,{0}、{1}、{2}分别表示j,i,j*i,单引号里面是输出格式。

print('{0}+{1}={2}'.format(j,i,j+i))。

第二种方法:类似于C语言格式输出,使用%开头格式输出。

print("%d + %d = %d" %(j,i,j+i))。

python中自动换行,要想不换行的话,需要在print括号最后面加上 , end = ''print(i, end = '' )。

Python常用格式字符是:

1、%s 字符串采用str()的显示。

2、%x 十六进制整数。

3、%r 字符串(repr())的显示。

4、%e 指数(基底写e)。

5、%c 单个字符。

6、%E 指数(基底写E)。

7、%b 二进制整数。

8、%f,%F 浮点数。

9、%d 十进制整数。

10、%g 指数(e)或浮点数(根据显示长度)。

11、%i 十进制整数。

12、%G 指数(E)或浮点数(根据显示长度)。

13、%o 八进制整数。

14、%% 字符%。

python的格式输出函数里面{:.2f}什么意思

d表示整型,f表示浮点型,就是指明数据类型用的。这跟C语言中的printf

函数语法是非常类似的,学过C语言的人就很容易理解这些。

print('test:{0:3}'.format(math.pi))3用于控制输出宽度。这里由于输出位数大于宽度,就按实际位数输出了。

print('test:{0:3f}'.format(math.pi))同样,3表示输出宽度。若输出位数小于此宽度,默认右对齐,左边补空格。如:

print('test:{0:10f}'.format(math.pi))test:

3.141593若输出位数大于宽度,则按实际位数输出。这里之所以显示3.141593,是因为指定了f浮点数类型,默认显示6位小数。print('test:{0:.3}'.format(math.pi)).3

指定除小数点外的输出位数print('test:{0:.3f}'.format(math.pi)).3f

表示浮点数的精度为3(小数位保留3位)

python中函数输出怎么使用

print函数是python语言中的一个输出函数,可以输出以下几种内容

1. 字符串和数值类型 可以直接输出

print( 1)

1

print( "Hello World")

Hello World

2.变量

无论什么类型,数值,布尔,列表,字典...都可以直接输出

x =  12

print(x)

12

s =  'Hello'

print(s)

Hello

L = [ 1, 2, 'a']

print(L)

[ 1,  2,  'a']

t = ( 1, 2, 'a')

print(t)

( 1,  2,  'a')

d = { 'a': 1,  'b': 2}

print(d)

{ 'a':  1,  'b':  2}

3.格式化输出

类似于C中的 printf

s

'Hello'

x = len(s)

print( "The length of %s is %d"  % (s,x) )

The length of Hello  is  5

【注意】

Python2和3的print函数格式不同,3要求加括号(print())

缩进最好使用4个空格

在python中,数据的输出用哪个函数名

Python3中使用:print()函数

用法(从IDLE帮助上复制):

print(...)

print(value, ..., sep=' ', end='\n', file=sys.stdout, flush=False)

Prints the values to a stream, or to sys.stdout by default.

Optional keyword arguments:

file: a file-like object (stream); defaults to the current sys.stdout.

sep: string inserted between values, default a space.

end: string appended after the last value, default a newline.

flush: whether to forcibly flush the stream.

value即你要输出的值(大多数类型均可),sep是这多个值用什么分割(默认为空格),end是这个输出的末尾是什么(默认是换行)。


文章标题:python语言输出函数,python语言输出函数帮助
链接分享:http://scjbc.cn/article/hopoei.html

其他资讯