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. day6_python学习笔记_chapter8_条件,循环

    1. if elif else 2. 条件表达式:三元操作符: smaller = x if x < y else y   == if x < y : smaller =x  else : ...

  2. R与数据分析旧笔记(十)非线性模型

    非线性模型 非线性模型 例子:销售额x与流通费率y > x=c(1.5,2.8,4.5,7.5,10.5,13.5,15.1,16.5,19.5,22.5,24.5,26.5)> y=c( ...

  3. web编程速度大比拼(nodejs go python)(非专业对比)

    C10K问题的解决,涌现出一大批新框架,或者新语言,那么问题来了:到底谁最快呢?非专业程序猿来个非专业对比. 比较程序:输出Hello World! 测试程序:siege –c 100 –r 100 ...

  4. for循环产生的Cortex-M3汇编代码的一个奇怪现象

    最近比较一下KEIL和IAR两个编译器产生的代码,基于Cortex-M3处理器的,然后发现了一几个奇怪的地方. 很简单的一个C的for循环 void fun_for_add_65535(void) { ...

  5. D3.js学习记录【转】【新】

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  6. UVA-548Tree(二叉树的递归遍历)

    Tree Time Limit: 3000MS   Memory Limit: Unknown   64bit IO Format: %lld & %llu Submit Status Des ...

  7. xmu1125 越野车大赛(三分)

    1125: 越野车大赛 Time Limit: 500 MS  Memory Limit: 64 MB  Special JudgeSubmit: 4  Solved: 3[Submit][Statu ...

  8. 用上Google才是正事 分享几个訪问Google的IP和域名

    通过VPN或者GAE等代理进行訪问,GAE下载请移步<GAE 3.1.18 最新版本号下载 用上Google才是正事>.这是大家通经常使用的办法.也有同学们不愿意使用代理软件.那今天来分享 ...

  9. Android-自己定义显示价格的PriceView

    转载请标明出处:http://blog.csdn.net/goldenfish1919/article/details/44418883 先看一下我们要做的效果: 价格分成了3部分.前面是一个¥,中间 ...

  10. HTML5API___manifest

    离线缓存 manifest 在html标签里面增加个属性 mainfest 就可以告诉浏览器缓存文件在哪里. <html manifest='show.manifest' xmlns=" ...