利用RPM和YUM安装软件
反射
python面向对象中的反射:通过字符串的形式操作对象相关的属性。python中的一切事物都是对象(都可以使用反射)
反射机制就是在运行时,动态的确定对象的类型,并可以通过字符串调用对象属性、方法、导入模块,是一种基于字符串的事件驱动。
解释型语言:程序不需要编译,程序在运行时才翻译成机器语言,每执行一次都要翻译一次。因此效率比较低。相对于编译型语言存在的,源代码不是直接翻译成机器语言,而是先翻译成中间代码,再由解释器对中间代码进行解释运行。比如Python/JavaScript / Perl /Shell等都是解释型语言。
python是一门解释型语言,因此对于反射机制支持很好。在python中支持反射机制的函数有getattr()、setattr()、delattr()、exec()、eval()、__import__,这些函数都可以执行字符串。
eval
计算指定表达式的值。它只能执行单个表达式,而不能是复杂的代码逻辑。而且不能是赋值表达式。 单个表达式
a = "12 + 43"
b = eval(a)
print(b)#55
exec
执行复杂表达式,返回值永远都是None
b = exec("aa = 21")
print(b) # None,exec返回值为None
print(aa) # 21,exec执行了赋值语句,并定义了aa变量
执行复杂语句
a = '''ret = []
for i in range(10):
ret.append(i)'''
exec(a)
print(ret) # [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
导入模块
config.py
KEYWORD = 123
# 导入模块
exec("import config")
print(config.KEYWORD) # 动态创建类
class Base:
def __init__(self):
print("Base") a = "Base"
exec(a+"()")
导入模块这个功能就非常屌了,这样我们就可以动态的创建各种模块类。
eval()函数和exec()函数的区别: eval()函数只能计算单个表达式的值,而exec()函数可以动态运行代码段。 eval()函数可以有返回值,而exec()函数返回值永远为None。
再看一下下面的例子:
class Base:
def __init__(self):
print("Base") def test(self):
print("test")
return "Base::test" a = "Base"
b = eval(a+"()")
# b = eval("b.test()")
b = exec("b.test()")
print(b)
输出: test Base::test 如果不需要获取返回值,那么可以使用exec,exec("a.test()"),输出:test
虽然我们可以使用eval和exec来执行以上代码,但是这种方式有一个缺陷,假如这个属性是不存在的,那么这种调用就会报错。那么做好的方式是什么呢?先判断属性是否存在,如果存在就调用,不存在就不调用,python为我们提供了一套方法:hasattr、getattr、setattr、delattr
一、getattr
对象获取
# coding:utf-8
class Manager:
role = "管理员"
def __init__(self,name,sex,phone,mail):
self.name = name
self.sex = sex
self.phone = phone
self.mail = mail def createClass(self):
print("create class") def createTeacher(self):
print("createTeacher") def createStu(self):
print("createStu") manager = Manager("safly","男",123456,123456) print("---对象获取对象方法-----")
f = getattr(manager,"createClass")
f() print("---对象获取对象属性-----")
name = getattr(manager,"name")
print(name) print("---对象获取类属性-----")
role = getattr(manager,"role")
print(role) print("---对象获取类属性(可以设置默认值)-----")
import logging
if hasattr(manager,"role1"):
role = getattr(manager,"role1","roleDefault")
print(role)
else:
logging.warn("没有role属性")
role = getattr(manager, "role1", "roleDefault")
print(role)
运行结果:
---对象获取对象方法-----
create class
---对象获取对象属性-----
safly
---对象获取类属性-----
管理员
---对象获取类属性(可以设置默认值)-----
WARNING:root:没有role属性
roleDefault
类获取
#coding=utf-8
class Manager:
role = "管理员"
def createClass(self):
print("create class") def createStu(self):
print("createStu") m = Manager() f = getattr(Manager,"createClass")
f(Manager()) f = getattr(Manager,"createClass")
f(m) role = getattr(Manager,"createStu")
role(m) #对象获取类属性
role = getattr(Manager,"role")
print(role)
Traceback (most recent call last):
File "E:/program/ljt_test/test/test2.py", line 13, in <module>
f(Manager)#参数需要是类实例,忘了写括号。
TypeError: unbound method createClass() must be called with Manager instance as first argument (got classobj instance instead)
运行输出:
create class
create class
createStu
管理员
二、setattr
设置类属性、方法
class Manager:
role = "管理员"
def __init__(self,name,sex,phone,mail):
self.name = name
self.sex = sex
self.phone = phone
self.mail = mail def createClass(self):
print("create class") manager = Manager("safly","男",123456,123456) print("----设置类属性------")
setattr(Manager,"country","china")
print(Manager.country) print("----删除类属性------")
delattr(Manager,"country")
# #删除报错
# print(Manager.country)
print("----设置类方法------")
@staticmethod
def Method(cls,parm):
print u"我是被绑定的class之外的方法parm--",parm setattr(Manager,"Method",Method)
Manager.Method(Manager,1)
运行结果:
----设置类属性------
china
----删除类属性------
----设置类方法------
我是被绑定的class之外的方法parm-- 1
设置对象属性、方法
#coding=utf-8
class Manager:
role = "管理员"
def __init__(self,name,sex,phone,mail):
self.name = name
self.sex = sex
self.phone = phone
self.mail = mail def createClass(self):
print("create class") def createTeacher(self):
print("createTeacher") def createStu(self):
print("createStu") manager = Manager("safly","男",123456,123456) print("----设置对象属性------")
setattr(manager,"age",20)
print(manager.age) print("----删除对象属性------")
delattr(manager,"age")
# 'Manager' object has no attribute 'age'
# print(manager.age) print("---对象不能删除类属性---")
setattr(Manager,"country","china")
print(Manager.country)
# delattr(manager,"country")
# print(Manager.country) print("----设置对象方法------")
def create_course(self):
print('创建了一个课程') setattr(manager,'create_course',create_course)
manager.create_course(manager) def create_grade():
print('创建了一个班级')
setattr(manager,'create_grade',create_grade) manager.create_grade()
print manager.__dict__
exit(0)
运行输出结果:
----设置对象属性------
20
----删除对象属性------
---对象不能删除类属性---
china
----设置对象方法------
创建了一个课程
创建了一个班级
{'name': 'safly', 'create_course': <function create_course at 0x022F6D30>, 'create_grade': <function create_grade at 0x023744F0>, 'sex': '\xe7\x94\xb7', 'phone': 123456, 'mail': 123456}
三、模块反射
创建一个模块mokuai.py
a = 1
def method(rag):
print(rag)
return ""
然后在python.py中导入以上模块
import mokuai
print(getattr(mokuai,"a"))
method = getattr(mokuai,"method")
ret = method(8888)
print(ret)
输出如下:
1
8888
666
四、反射本模块函数、变量
#coding=utf-8
aa = 11
def method():
print("---method---")
import sys print(sys.modules[__name__])
print(getattr(sys.modules[__name__],"aa"))
f = getattr(sys.modules[__name__],"method")
f()
输出如下:
<module '__main__' from 'E:/program/ljt_test/test/test2.py'>
11
---method---
三、hasattr
hasattr(object, name)
判断object对象中是否存在name属性,当然对于python的对象而言,属性包含变量和方法;有则返回True,没有则返回False;需要注意的是name参数是string类型,所以不管是要判断变量还是方法,其名称都以字符串形式传参;getattr和setattr也同样;
#coding=utf-8
class A():
name = 'python'
def func(self):
return 'A()类的方法func()' print hasattr(A, 'name') print hasattr(A, 'age') print hasattr(A, 'func')
运行结果:
True
False
True
https://cloud.tencent.com/developer/article/1447119
https://cloud.tencent.com/developer/article/1156663
https://www.cnblogs.com/zanjiahaoge666/p/7475225.html
利用RPM和YUM安装软件的更多相关文章
- Linux之保留yum安装软件后的RPM包
yum安装软件很方便,但是下载下来的rpm包在安装后默认会被删除掉: 如果希望保留yum安装的软件包该如何做呢? 设置方法: 将/etc/yum.conf里对应的keepcache参数改为1即可,然后 ...
- linux rpm yum 安装 软件
rpm 安装: 1.rpm包的了解: rpm 安装 升级 删除 rpm -ivh ****.rpm 安装 rpm -Uvh ****.rpm 升级 rpm -e name 删除 ...
- CentOS中yum安装软件时报错:No package XXX available
yum 安装软件时,报错:No package XXX available. [root@localhost ~]# yum -y install redis Loaded plugins: fast ...
- yum install错误 系统环境:Oracle Linux5.4 在通过yum安装软件时出现以下错误:
1.yum配置文件 1 [root@rh168 yum.repos.d]# cat yum.repo 2 [base] 3 name=Oracle linux 4 baseurl=file:/// ...
- CentOS下成功挂载xxxxxDVDx.iso并使用yum安装软件
CentOS下成功挂载xxxxxDVDx.iso并使用yum安装软件 **不断尝试,终能到达彼岸** 测试环境为Win7 32位,VirtualBOx4.2.16+CentOS6.5,可分别到virt ...
- Red Hat Enterprise Linux Server(RHEL) yum安装软件时This system is not registered with RHN. RHN support will be disabled. 的解决方法(转)
新安装了redhat6.5.安装后,登录系统,使用yum update 更新系统.提示: This system is not registered to Red Hat Subscription M ...
- linux 基本命令___0003 字符串处理和yum安装软件的路径
字符串变量的处理 参考链接:SHELL字符串处理技巧 计算字符串的字符数量: ${#str} str="xxx-Lane1_S2_L001_R1_trim.fastq" echo ...
- 开发环境入门 linux基础(部分)虚拟内存,rpm和yum安装
虚拟内存,rpm和yum安装 文本中查找 /内容 替换:扩展模式下(:)%s /替换目标/要替换的文件/ (只替换第一个)(后边加g全部替换) :set u添加行号 raid lvm逻辑卷 df - ...
- CentOS yum安装软件时保留安装包及依赖包或者自动下载安装包及相关依赖包
CentOS上安装某个软件一般都有很多相关的依赖包,当然,这也与我们安装时software selection步骤中选择的版本有关系,我们服务器在安装CentOS时一般选择Basic Web Serv ...
随机推荐
- Java自定义注解基础知识
注解分为三类:没有任何元素的注解,有一个元素的注解和有多个元素的注解. 1. Marker注解 这类注解没有任何元素,此类注解仅仅是一个标示.如下所示: public @interface Good ...
- 记一次vue2路由参数传递this指针问题
需要船体一个data()内的对象到另一个页面. <player-card v-for="(note, key) in sortedtNodes" :imgurl=" ...
- Android技术——在Android中的随意视图中找控件
1.在非常多情况下,我们可能不知道控件的id,可是我们却希望在包括这个控件的视图中找到它,能够採用例如以下做法: 例:在Activity的根视图中找出当中全部的Button控件 private voi ...
- [Erlang]Erlang经常使用工具解说
原创文章,转载请注明出处:服务器非业余研究http://blog.csdn.net/erlib 作者Sunface 联系邮箱:cto@188.com 但凡有图形界面的都须要linux系统安装了wx图形 ...
- 【资料总结】html开发小实例
目 录 第1章 1 HTML的基本标签 1 第2章 25 表格基础 25 第3章 53 表单和框架 53 第4章 77 CSS样式表 77 第5章 104 使用Dreamweaver制作网页 104 ...
- 倍福TwinCAT(贝福Beckhoff)常见问题(FAQ)-如何在初始化的时候写入参数
最常见的是定义一个全局变量,然后跟对应的变量绑定,比如我定义了一个SINT型的变量ControlWord 数值是8,定义好之后编译一下,可以发现PLC程序中或多出来这个变量(MAIN.ControlW ...
- 近期面试Android的一些面试题
近期一个多月面试过一下公司(均为实习): 腾讯:内推一面卒. 正式校招拿到offer 阿里:内推二面卒. 蘑菇街:面完三面技术面,等待HR面 网易:拿到offer. 能够看到,大部分问题不难,可是能回 ...
- leetcode第一刷_Combination Sum Combination Sum II
啊啊啊啊.好怀念这样的用递归保存路径然后打印出来的题目啊.好久没遇到了. 分了两种,一种是能够反复使用数组中数字的,一种是每一个数字仅仅能用一次的.事实上没有多大差别,第一种每次进入递归的时候都要从头 ...
- 让你的 wowza server提供 RESTful web 服务
有时我们 nginx 须要和 wowza 服务器交互以进行一些 LB 事宜:有时我们的管理员须要实时了解 wowza 服务器的一些其它状态信息(比方一些自己定义对象的状态等等).而用 ...
- 06-hibernate注解-一对多单向外键关联
一对多单向外键 1,一方持有多方的集合,一个班级有多个学生(一对多). 2,@OneToMany(cascade={CascadeType.ALL}, fetch=FetchType.LAZY ) / ...