Jinja2模板注入 | python模板注入特殊属性 / 对象讲解

在进行模板利用的时候需要使用特殊的属性和对象进行利用,这里对这些特殊属性及方法进行讲解

以下实验输出python3版本为 3.10.4python2版本为 2.7.13

特殊属性

  • __class__ 类实例上使用,它用于获取该实例对应的类
  • __base__ 用于获取父类
  • __mro__ (Method Resolution Order)。__mro__ 属性返回一个元组,其中包含了类的继承链

特殊方法

  • __subclasses__() 获取直接子类

其他

  • __globals__ 一个特殊的变量,不使用在类上,而是用于函数,获取全局变量的字典
  • __builtins__ 它包含了 Python 内置的函数、异常和对象。这个模块使内置函数和对象在全局作用域中可用,无需显式导入

👉 目录


一、特殊属性

__class__

使用在实例上,获取该实例对应的类

csharp 复制代码
class A:
    pass
csharp 复制代码
print(A)	# 类
# __main__.A

print(A())	# 实例
# <__main__.A instance at 0x0000000002BA2348>

关系如下

csharp 复制代码
A().__class__ == A
# True

__base__

使用在类上,获取父类

csharp 复制代码
class A:
    pass

class B(A):
    pass

这里分两个情况, python2和python3

python2

csharp 复制代码
print(B)
# __main__.B

python3

csharp 复制代码
print(B)
# <class '__main__.B'>

我对这两个表示也不是很理解,但是只有python3这种表示方式才能使用 __base__

比如python3

csharp 复制代码
print(B.__base__)
# <class '__main__.A'>

可以看到结果是父类 A

python2我这里使用自带的类来演示
() 是tuple的实例
"" 是str的实例
[] 是list的实例

csharp 复制代码
print(().__class__)
print("".__class__)
print([].__class__)

# <class 'tuple'>
# <class 'str'>
# <class 'list'>

可以发现输出的格式和python3输出自定义类的相似

这里就可以使用 __base__

csharp 复制代码
print(().__class__.__base__)
# <class 'object'>

__mro__

返回类的继承链

csharp 复制代码
class A:
    pass

class B(A):
    pass

class C(B):
    pass

这里使用python3演示,因为要以下输出格式才有效

csharp 复制代码
<class 'xxx'>

python2 创建自定义类时没有这种效果

csharp 复制代码
print(C.__mro__)
# (<class '__main__.C'>, <class '__main__.B'>, <class '__main__.A'>, <class 'object'>)

创建类时默认继承Object,所以继承链一共有3个对象

如果B此时多继承个D,那么C.__mro__ 就会有4个对象


二、特殊方法

__subclasses__()

获取直接子类

__mro__不同,__subclasses__() 是一个方法,获取直接子类

csharp 复制代码
class A:
    pass

class B(A):
    pass

class C(B):
    pass

class D(A):
    pass

这里同样使用python3做演示,返回的是一个列表

csharp 复制代码
print(A.__subclasses__())
# [<class '__main__.B'>, <class '__main__.D'>]

三、其他

__globals__

一个特殊的变量,不使用在类上,而是用于函数,获取全局变量的字典

csharp 复制代码
hello = "hello"
world = "world"
csharp 复制代码
print(test.__globals__)
# {'__name__': '__main__', '__doc__': None, '__package__': None, '__loader__': <_frozen_importlib_external.SourceFileLoader object at 0x00000211AE5D4A60>, '__spec__': None, '__annotations__': {}, '__builtins__': <module 'builtins' (built-in)>, '__file__': 'C:\\Users\\wlb\\Desktop\\test\\python\\7.py', '__cached__': None, 'hello': 'hello', 'world': 'world', 'test': <function test at 0x00000211AE173E20>}

可以看到有很多键值对,几个熟悉的键值对

csharp 复制代码
'hello': 'hello', 
'world': 'world', 
'test': <function test at 0x000001FDD5E23E20>

上面有的键都可以直接使用 print打印出来

比如最常见的

csharp 复制代码
print(__name__)

__builtins__

它包含了 Python 内置的函数、异常和对象。这个模块使内置函数和对象在全局作用域中可用,无需显式导入

我们直接可以使用的函数和对象都在该变量上

csharp 复制代码
print(__builtins__.print == print)
# True

相关推荐
踏着七彩祥云的小丑9 小时前
pytest——Mark标记
开发语言·python·pytest
不爱吃炸鸡柳10 小时前
Python入门第一课:零基础认识Python + 环境搭建 + 基础语法精讲
开发语言·python
Dxy123931021611 小时前
Python基于BERT的上下文纠错详解
开发语言·python·bert
SiYuanFeng12 小时前
Colab复现 NanoChat:从 Tokenizer(CPU)、Base Train(CPU) 到 SFT(GPU) 的完整踩坑实录
python·colab
炸炸鱼.13 小时前
Python 操作 MySQL 数据库
android·数据库·python·adb
_深海凉_13 小时前
LeetCode热题100-颜色分类
python·算法·leetcode
AC赳赳老秦14 小时前
OpenClaw email技能:批量发送邮件、自动回复,高效处理工作邮件
运维·人工智能·python·django·自动化·deepseek·openclaw
zhaoshuzhaoshu14 小时前
Python 语法之数据结构详细解析
python
AI问答工程师14 小时前
Meta Muse Spark 的"思维压缩"到底是什么?我用 Python 复现了核心思路(附代码)
人工智能·python
zfan52015 小时前
python对Excel数据处理(1)
python·excel·pandas