我们在来复习一下反射
#demo.py中的程序
#!/usr/bin/env python
#coding:utf-8
def Foo():
print "demo.foo"
#主程序
#!/usr/bin/env python
#coding:utf-8
str1 = 'demo'
str2 = 'Foo'
module = __import__(str1) # == import demo
funk = getattr(module, str2)
#getattr相当于房户户demo模块中的Foo函数
funk()
#可以看到getater就是找到foo函数,并且赋给funk函数。
结果:demo.foo
我们引入反射的应用实例
#account.py文件
#!/usr/bin/env python
#coding:utf-8
#登录网站相关文件
def login():
print 'login'
def logout():
print 'logout'
#index.py文件
#!/usr/bin/env python
#coding:utf-8
from backend import account
data = raw_input("请输入URL:")
array = data.split('/')
if data == 'accout/login':
account.login()
elif data == 'account/logout':
account.logout()
#这里我们的大型网站如果有100个URL是不是我们要写100个if呢,这里我们就可以用反射动态获取。在下面介绍
一般web获取URL的原理
#这里admin.py和account.py都时我们URL的一个分页面
#admin.py文件
#!/usr/bin/env python
#coding:utf-8
def index():
print '欢迎登陆后台管理'
#account.py文件
#!/usr/bin/env python
#coding:utf-8
#登录网站相关文件
def login():
print 'login'
def logout():
print 'logout'
#index.py文件
#!/usr/bin/env python
#coding:utf-8
data = raw_input("请输入URL:")
array = data.split('/')
userspance = __import__('backend.'+array[0])
model = getattr(userspance, array[0])
func = getattr(model, array[1])
#相当于先导入一个文件夹,在文件夹中在导入那个模块,在执行函数。
#这里__import__ 相当于先导入import backend.account,然后在导入模块,在执行login()函数,也就是跟正常的没有区别,先import backend,然后backend.account,然后在backend.account.login
#这里我们正常导入模块时 import bachend.account ,执行的时候是使用backend.account.login(),所以我们这里在使用两次次getattr,这下应该差不多明白了
func()
#一次执行结果:
请输入URL:admin/index
欢迎登陆后台管理
名称栏目:反射的应用
文章源于:
http://chengdu.cdxwcx.cn/article/gsjchp.html