python 知识点:反射 之 getattr()实现以字符串形式导入模块和执行函数

本文涉及的产品
RDS MySQL DuckDB 分析主实例,基础系列 4核8GB
RDSClaw,2核4GB
RDS DuckDB + QuickBI 企业套餐,8核32GB + QuickBI 专业版
简介:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
# -*- coding: utf-8 -*-
#知识点:反射
#通过字符串的形式去导入模块,这就是反射
#并以字符串的形式执行函数
 
#先看简单的小粒子
temp  =  'mysql'  #这个字符串是模块的名字(也就是mysql.py或sqlserver.py,后缀名不用写)
func  =  'count'  #这个字符串是函数的名字(也就是mysql.py/sqlserver.py中的函数count)
model  =  __import__ (temp)     #以字符串的形式导入模块
 
#执行模块中的函数第一种方法
print  model.count() 
 
#执行模块中的函数第二种方法
Function  =  getattr (model,func)  #以字符串的形式执行函数
print  Function()
 
 
#下面模拟一个数据库连接的小粒子
#准备以下两个文件
 
'''
mysql.py文件模拟连接mysql数据库,连接正常返回1
# -*- coding: utf-8 -*-
def count():
     return 1
 
sqlserver.py文件模拟连接sqlserver数据库,连接正常返回2
# -*- coding: utf-8 -*-
def count():
     return 2
 
'''
#注意:mysql.py和sqlserver.py两个文件自行定义即可,这里近用于模拟作用
#并非是实际连接数据库的语句
 
def  db_count(db_name):
     temp  =  db_name  #模块的名字(也就是mysql或sqlserver)
     func  =  'count'  #函数的名字(也就是mysql.py/sqlserver.py中的函数count)
     model  =  __import__ (temp)
     Function  =  getattr (model,func)  #以字符串的形式执行函数
     return  Function()
 
#目前模拟的是默认连接sqlserver数据库
status  =  db_count( 'sqlserver' )
 
#检查连接sqlserver的状态(正常状态为:2),如果不能连接,则切换连接到mysql
if  status ! =  2 :
     status  =  db_count( 'mysql' )
     print  '已切换为mysql,连接ID:%d'  %  status
else :
     print  'sqlserver连接正常,连接ID:%d'  %  status
 
#测试动作:
#1、可将sqlserver.py中的count返回值修改成3



本文转自 TtrToby 51CTO博客,原文链接:http://blog.51cto.com/freshair/1870771

相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://www.aliyun.com/product/rds/mysql 
相关文章
|
6月前
|
SQL 关系型数据库 数据库
Python SQLAlchemy模块:从入门到实战的数据库操作指南
免费提供Python+PyCharm编程环境,结合SQLAlchemy ORM框架详解数据库开发。涵盖连接配置、模型定义、CRUD操作、事务控制及Alembic迁移工具,以电商订单系统为例,深入讲解高并发场景下的性能优化与最佳实践,助你高效构建数据驱动应用。
775 7
|
6月前
|
存储 JavaScript Java
(Python基础)新时代语言!一起学习Python吧!(四):dict字典和set类型;切片类型、列表生成式;map和reduce迭代器;filter过滤函数、sorted排序函数;lambda函数
dict字典 Python内置了字典:dict的支持,dict全称dictionary,在其他语言中也称为map,使用键-值(key-value)存储,具有极快的查找速度。 我们可以通过声明JS对象一样的方式声明dict
407 1
|
6月前
|
监控 安全 程序员
Python日志模块配置:从print到logging的优雅升级指南
从 `print` 到 `logging` 是 Python 开发的必经之路。`print` 调试简单却难维护,日志混乱、无法分级、缺乏上下文;而 `logging` 支持级别控制、多输出、结构化记录,助力项目可维护性升级。本文详解痛点、优势、迁移方案与最佳实践,助你构建专业日志系统,让程序“有记忆”。
511 0
|
6月前
|
Java 数据处理 索引
(numpy)Python做数据处理必备框架!(二):ndarray切片的使用与运算;常见的ndarray函数:平方根、正余弦、自然对数、指数、幂等运算;统计函数:方差、均值、极差;比较函数...
ndarray切片 索引从0开始 索引/切片类型 描述/用法 基本索引 通过整数索引直接访问元素。 行/列切片 使用冒号:切片语法选择行或列的子集 连续切片 从起始索引到结束索引按步长切片 使用slice函数 通过slice(start,stop,strp)定义切片规则 布尔索引 通过布尔条件筛选满足条件的元素。支持逻辑运算符 &、|。
336 0
|
6月前
|
JSON 算法 API
Python中的json模块:从基础到进阶的实用指南
本文深入解析Python内置json模块的使用,涵盖序列化与反序列化核心函数、参数配置、中文处理、自定义对象转换及异常处理,并介绍性能优化与第三方库扩展,助你高效实现JSON数据交互。(238字)
571 4
|
6月前
|
Java 调度 数据库
Python threading模块:多线程编程的实战指南
本文深入讲解Python多线程编程,涵盖threading模块的核心用法:线程创建、生命周期、同步机制(锁、信号量、条件变量)、线程通信(队列)、守护线程与线程池应用。结合实战案例,如多线程下载器,帮助开发者提升程序并发性能,适用于I/O密集型任务处理。
653 0
|
6月前
|
XML JSON 数据处理
超越JSON:Python结构化数据处理模块全解析
本文深入解析Python中12个核心数据处理模块,涵盖csv、pandas、pickle、shelve、struct、configparser、xml、numpy、array、sqlite3和msgpack,覆盖表格处理、序列化、配置管理、科学计算等六大场景,结合真实案例与决策树,助你高效应对各类数据挑战。(238字)
809 0
|
7月前
|
数据采集 机器学习/深度学习 人工智能
Python:现代编程的首选语言
Python:现代编程的首选语言
1100 102
|
7月前
|
数据采集 机器学习/深度学习 算法框架/工具
Python:现代编程的瑞士军刀
Python:现代编程的瑞士军刀
441 104
|
7月前
|
人工智能 自然语言处理 算法框架/工具
Python:现代编程的首选语言
Python:现代编程的首选语言
349 103

推荐镜像

更多
下一篇
开通oss服务