Python 再谈变量作用域与变量引用
再谈变量作用域与变量引用
by:授客 QQ:1033553122
module3.py
#!/usr/bin/env python
# -*- coding:utf-8 -*-
__author__ = 'shouke'
var = 'var_in_module3'
module2.py
#!/usr/bin/env python
# -*- coding:utf-8 -*-
__author__ = 'shouke'
from module3 import var
class ClassOne:
var = 'global var in ClassOne' # 类中的全局变量
def func(self):
print('var in func for ClassOne: %s' % var) # 引用module3.var
ClassOne.var = 'var whose value changed in func of ClassOne'
module1.py
#!/usr/bin/env python
# -*- coding:utf-8 -*-
__author__ = 'shouke'
from module3 import var
from module2 import ClassOne
def function():
print('var in function: %s' % var) # 引用module3.var
var1 = 'value_for_var1'
if True:
print('var1 in if: %s' % var1)
var1 = 'value_changed_for_var1'
print('var1 in if: %s' % var1)
print('var1 out of if: %s' % var1)
print('\nbegan for loop \n')
for num in range(1, 2):
var1 = 'var1_in_for_loop'
if True:
print('var1 in if for loop: %s' % var1)
var1 = 'value_changed for var1 in if for_loop'
print('var1 in if for loop: %s' % var1)
print('var1 out of if for loop: %s' % var1)
print('var1 out of for loop: %s' % var1)
class ClassTwo:
def func(self):
var = ClassOne.var # 引用值
print('var in func of ClassTwo: %s' % var)
def func2(self):
ClassOne.var = 'value changed in ClassTwo' # 修改值
if __name__ == '__main__':
function()
print('\n')
obj1 = ClassTwo()
obj1.func()
obj2 = ClassOne()
obj2.func()
print('\n')
obj2.func()
obj1.func()
print('\n')
obj1.func2()
obj2.func2()
输出:
说明:
1、如何在不同模块中引用同一个变量?
答案:在一个模块中定义一个全局变量并赋值,然后在其它模块中通过导入定义的变量,在适当的位置引用该变量,如上例中,在module3中定义一个变量,然后通过语句 from module3 import var 导入变量
2、如何在类中定义一个全局变量?
答案:
class ClassName:
var_name = xxxxxxxx
在其它模块中,通过导入该类,然后通过ClassName.var_name方式引用变量,或者给变量赋值。
3、try……except,if,for,while子句中的变量作用域与赋值
举例说明
Python 再谈变量作用域与变量引用的更多相关文章
- javascript中的变量作用域以及变量提升
在javascript中, 理解变量的作用域以及变量提升是非常有必要的.这个看起来是否很简单,但其实并不是你想的那样,还要一些重要的细节你需要理解. 变量作用域 “一个变量的作用域表示这个变量存在的上 ...
- javascript中的变量作用域以及变量提升详细介绍
在javascript中, 理解变量的作用域以及变量提升是非常有必要的.这个看起来是否很简单,但其实并不是你想的那样,还要一些重要的细节你需要理解变量作用域 “一个变量的作用域表示这个变量存在的上下文 ...
- 再谈java两种变量(基本类型和引用类型)(综合各路大神)
基本类型: 基本类型自然不用说了,它的值就是一个数字,一个字符或一个布尔值. int a: a=250: //声明变量a的同时,系统给a分配了数据空间. 引用类型: 是一个对象类型,值是什么呢? ...
- PHP变量作用域以及地址引用问题
作用域的概念: 在PHP脚本的任何位置都可以声明变量,但是,声明变量的位置会大大影响访问变量的范围.这个可以访问的范围称为作用域. 主要的常用的包括:局部变量.全局变量.静态变量. 1.局部变量:就是 ...
- js的变量作用域 ,变量提升
(function(){ a = 5; alert(window.a); var a = 10; alert(a); })(); 结果: undefined 10 代码等同于下面 var a = un ...
- [TimLinux] Python 再谈元类 metaclass
本博文通过对以下链接进行理解后,编写. https://stackoverflow.com/questions/100003/what-are-metaclasses-in-python 1. 类 类 ...
- [TimLinux] Python 再谈装饰器
参考链接:https://stackoverflow.com/questions/739654/how-to-make-a-chain-of-function-decorators 1. 函数对象 能 ...
- Python 再谈字符串
字符串除了要用引号来创建之外,其他和元组一样,不能修改,如果要修改只能用切片或者拼接的方式. 其他的什么乱七八糟的运算符都一样 一些不同 capitalize()-将字符串的第一个字母大写 str1. ...
- JavaScript基础——理解变量作用域
一旦你开始在JavaScript应用程序中添加条件.函数和循环,就需要理解变量作用域.变量作用域规定了如何确定正在执行的代码行上的一个特定变量名的值. JavaScript允许你既定义全局版本又定义局 ...
随机推荐
- go操作redis
package main import ( "fmt" "github.com/gomodule/redigo/redis" ) func main() { c ...
- Javascript百学不厌 - 尾递归
虽然偶尔也用过,但是从来没具体来整理过 普通递归: function fac(n) { ) ; ); } fac() 这是个阶乘.但是占用内存,因为: fac(5) (5*fac(4)) (5*(4* ...
- hdu 6161--Big binary tree(思维--压缩空间)
题目链接 Problem Description You are given a complete binary tree with n nodes. The root node is numbere ...
- web自动化测试---selenium分布式测试
使用selenium框架还可以进行分布式测试,操作如下: 准备俩台PC:A和B,ip分别为IP_A和IP_B 下载最新的selenium-standalone的jar包,可以到下面地址下载各版本的包: ...
- Maven setting配置镜像仓库
国内Maven镜像仓库值得收藏 1.配置IDE构建的Maven存放目录(解压目录) 2.配置IDE的User setting file路径,修改setting配置文件 配置本地仓库 <!-- ...
- Android的Fragment中的互相通信-桥梁activity
Android的Fragment中的互相通信-桥梁activity 效果图如下: 项目结构图如下: Fragment1: package com.demo.fragmenttongxin; impor ...
- Vue + Element UI 实现权限管理系统 前端篇(十五):嵌套外部网页
嵌套外部网页 在有些时候,我们需要在我们的内容栏主区域显示外部网页.如查看服务端提供的SQL监控页面,接口文档页面等. 这个时候就要求我们的导航菜单能够解析嵌套网页的URL,并根据URL路由到相应的嵌 ...
- leetcode — generate-parentheses
import java.util.ArrayList; import java.util.Arrays; import java.util.List; /** * Source : https://o ...
- Ubuntu中root的默认密码
原文地址:http://www.cnblogs.com/xuyingying/archive/2008/10/16/1312584.html 安装完Ubuntu后忽然意识到没有设 置root密码,不知 ...
- HTML5 audio元素如何使用js与jquery控制其事件
前言: 每一次遇见问题想到的就是怎么解决?最好的方法还是查询网络媒体,更好的办法是让自己记忆,只有自己理解到了才真正是属于自己.要做一个订单提醒功能,没有使用audio相关的插件,虽然插件无数,还是喜 ...