python中的变量:

一个变量是局部还是全局,在编译函数的时候就已经决定,因此读变量值的时候也不会逐层向外查找。变量是全局还是局域,根据如下3条:

  1. 如果函数内部有global语句,那么它声明的变量是全局的。

  2. 如果函数内部有对变量的赋值语句,那么它是局域的。

  3. 除此之外都是全局的。

注意1和2,和语句的位置无关,只要有这样的语句,那么它的范围就确定了。例如:

  1. def f():
  2. print x
  3. if 0:
  4. x = 1

上面的程序中存在x=1,因此x为局域变量。(运行报错)

  x = 0

  def  f():
    print x

上面的程序不报错,x为全局变量,符合第三条  

只有一种特例会逐层向外查找,函数体内存在exec语句时,例如:

  1. def f3():
  2. exec("")
  3. a = 1
  4. global b
  5. print a,b,c

在这个程序中,根据规则1和2,a是局域,b是全局。而c符合第3种情况,但存在exec语句,因此它变成了逐层向外查找,这样可以应付exec("c=100")这样的情况,读取c时,先在locals()中查找c,找不到的话就在全局globals()中寻找。

Python 支持4种参数传递的方式:

1.定义:

F(a,b)

调用:

F(1,2)

2.定义:

F(a,b=9)

调用:

F(1) 或 F(1,2)  #第二个参数未给出的话,使用默认的值 9

3.定义:

F(*a)

调用:

F(1) 或 F(1,2)或F(1,2,3)

#这种方式可以接收任意多个参数保存到名为a的元组中,在函数内部可通过a元组访问这些参数

4.定义:

F(**a)

调用:

F(x=1)或F(x=1,y=2)

## 这种方式同样可以接收任意多个参数,并将参数保存到名为a的字典中,字典表示为{'x':1}或{'x':1,'y':2}

上面*号都是出现在函数的定义中

其实*号同样可以出现在函数的调用中,实际效果与在定义中使用刚好相反,下面给出实例代码:

  1.  #!/usr/bin/env python
    def F(a,b):
    print a,b argv = (1,2)
    #argv = [1,2]
    #argv = {'a':1,'b':2}
    F(*argv)  

调用 F(*argv),将输出 1,2

将argv 定义成代码中注释掉的列表,字典仍然有效,且对于字典F(*argv)与F(**argv) 调用结果相同

由此我们可以这样理解:

函数定义中的 * ,用于将多余的参数合并为一个元组 (对于 ** 是合并为字典)

函数调用中的* ,用于将元组或列表或字典参数,分解为单个的变量值,并做为参数传递 (ps:暂时只能这样表述了 )

Python 参数传递的更多相关文章

  1. Python参数传递(传值&传引用)

    # 测试参数是传值还是传引用def test(arg): print("test before") print(id(arg)) arg[1]=30 # 测试可变对象 # arg[ ...

  2. Python参数传递,既不是传值也不是传引用

    面试的时候,有没有被问到Python传参是传引用还是传值这种问题?有没有听到过Python传参既不是传值也不是传引用这种说法?一个小小的参数默认值也可能让代码出现难以查找的bug? 如果你也遇到过上面 ...

  3. Python学习日记(十)—— 杂货铺(全局变量补充、Python参数传递、字符串格式化、迭代器、生成器)

    全局变量补充 python自己添加了些全局变量 print(vars()) """结果: {'__name__': '__main__', '__doc__': None ...

  4. Python参数传递中的 args, kwargs

    概念 真正的Python参数传递语法是*和**,其被称为 被称为打包和解包参数.*args和**kwargs只是大家默认的一种形式.也可以写成*keys和**kkeys等其他形式.二者都是为了在不知道 ...

  5. python 参数传递 传值还是传引用

    个人推测结论: 可变对象传引用,不可变对象传值 python里的变量不同于c中地址储值模型 a=100 b=100 print(id(a),id(b),a==b,a is b) #8790877986 ...

  6. python参数传递:对象的引用

    大家都知道在python中,一切皆对象,变量也不再具有类型,变量仅仅是对象的一个引用,我们通常用变量来测类型,通常测得就是被这个变量引用得对象的类型. python采用的是传递对象的引用,为了方便说明 ...

  7. python参数传递

    1.形式参数:在定义函数时,函数名后面括号中的参数为“形式参数”,也称形参 2.实际参数:在调用一个函数时,函数名后面括号种的参数为“实际参数”,也就是将函数的调用者提供给函数的参数称为实际参数,也称 ...

  8. Python引用复制,参数传递,弱引用与垃圾回收

    引用 先上个示例: >>> val = [1] >>> val[0] = val >>> val [[...]] 上述代码使val中包含自身,而产 ...

  9. Python中的参数传递问题

    首先需要说明python中元组,列表,字典的区别. 列表: 什么是列表呢?我觉得列表就是我们日常生活中经常见到的清单. 例如:lst = ['arwen',123] 向list中添加项有两种方法:ap ...

随机推荐

  1. mysql的触发器

    删除触发器 drop TRIGGER 触发器名字; 查找库里面的所有触发器 SELECT * FROM information_schema.`TRIGGERS`;show triggers 触发器语 ...

  2. html5 canvas 运行起来绝对让你震撼!

    从一个大神那看到的,拷贝过来跟大家分享下! html <canvas></canvas> *{margin:0;padding:0;}body{background:#222; ...

  3. 0617 python 基础04

    控制流--for 循环 >>> range(10) [0, 1, 2, 3, 4, 5, 6, 7, 8, 9] 换行输出 >>> for i in range(1 ...

  4. python 常用模块及方法

    ******************** PY核心模块方法 ******************** os模块: os.remove()         删除文件 os.unlink()        ...

  5. ProFTPD 初探

    ProFTPD:一个Unix平台上或是类Unix平台上(如Linux, FreeBSD等)的FTP服务器程序.

  6. LINQ to SQL的CRUD操作

    创建数据对象模型 sqlmetal /code:"C:\MyProjects\VS2008\Data\LinqConsoleApp2\LinqConsoleApp2\northwnd.cs& ...

  7. openstack 源码分析

    Nova对于底层Hypervisor(如KVM/QEMU等)的调用与管理主要通过LibvirtDriver类,nova/virt/libvirt/driver.py Libvirt对Hyperviso ...

  8. ASP.NET MVC导入excel到数据库

    MVC导入excel和webform其实没多大区别,以下为代码: 视图StationImport.cshtml的代码: @{ ViewBag.Title = "StationImport&q ...

  9. POJ 3461 Oulipo(模式串在主串中出现的次数)

    题目链接:http://poj.org/problem?id=3461 题意:给你两个字符串word和text,求出word在text中出现的次数 思路:kmp算法的简单应用,遍历一遍text字符串即 ...

  10. JS学习之闭包的理解

    一.变量的作用域 要理解闭包,首先必须理解Javascript特殊的变量作用域.变量的作用域无非就是两种:全局变量和局部变量.Javascript语言的特殊之处,就在于函数内部可以直接读取全局变量.另 ...