m = inspect.getmembers(module, inspect.isfunction)是什么意思
时间: 2023-05-24 10:04:20 浏览: 70
这行代码的意思是,调用inspect模块的getmembers方法,将一个模块对象module作为第一个参数传入,以函数为筛选条件(inspect.isfunction)来获取该模块中所有的函数对象并返回。返回结果是一个由元组组成的列表,每个元组包括函数名和函数对象两个元素。
相关问题
import pywinauto import inspect app = pywinauto.Application().connect(title='窗口标题') window = app.window(title='窗口标题') ctrls = inspect.getmembers(window, lambda c: isinstance(c, pywinauto.controls.win32_controls)) for ctrl in ctrls: print(ctrl)运行后提示TypeError: isinstance() arg 2 must be a type, a tuple of types, or a union错误
这个错误的原因是在使用 `isinstance` 函数时传入了错误的参数。`isinstance` 函数的第二个参数应该是一个类型(type)或类型元组(tuple of types),用于判断第一个参数是否是该类型或类型元组中的任意一种类型的实例。因此,这里应该将 `pywinauto.controls.win32_controls` 改为一个类型或类型元组。
你可以尝试将代码修改为以下形式来解决这个问题:
```python
import pywinauto
import inspect
app = pywinauto.Application().connect(title='窗口标题')
window = app.window(title='窗口标题')
ctrls = inspect.getmembers(window, lambda c: isinstance(c[1], pywinauto.controls.win32_controls.__class__))
for ctrl in ctrls:
print(ctrl)
```
这里我们使用了 `pywinauto.controls.win32_controls.__class__` 来获取 `win32_controls` 这个类的类型,然后将其传入 `isinstance` 函数中。同时,由于 `inspect.getmembers` 函数返回的是一个列表,其中每个元素都是一个键值对,所以在 lambda 函数中使用 `c[1]` 来获取每个控件的实例。
class ApprovalFlow(models.Model): _name = 'approval.flow' _description = u'审批流程' def _compute_domain(self): all_cls = inspect.getmembers(sys.modules[__name__], inspect.isclass) odoo_cls = [getattr(cls[1], '_name') for cls in all_cls if cls[1].__bases__[0].__name__ == 'Model'] # 排除当前的对象 odoo_cls += [model.model for model in self.env['ir.model'].search([('transient', '=', True)])] # 排除临时对象 return [('model', 'not in', odoo_cls)] approval_cannot_run = fields.Char(u'完成后不能执行操作', help=u'审批流程完成后不能能执行的操作,修改,删除', store=True) name = fields.Char(u'名称') model_id = fields.Many2one('ir.model', u'模型', domain=_compute_domain, index=1) 如果选择完成后不能删除重写生成方法怎么写
如果您想在完成审批流程后禁止对该记录进行删除操作,可以尝试重写Odoo的“unlink”方法。您可以将以下代码添加到您的“ApprovalFlow”类中:
```python
@api.multi
def unlink(self):
for flow in self:
if flow.state != 'draft':
raise UserError(_('Cannot delete a record in approval flow.'))
return super(ApprovalFlow, self).unlink()
```
在这个新的“unlink”方法中,我们首先检查当前记录的状态是否为“draft”,如果不是,则抛出一个用户错误,阻止删除操作。如果状态为“draft”,则调用原始的“unlink”方法以正常执行删除操作。
请注意,在重写Odoo的方法时,尽量不要直接修改原始方法。相反,您应该使用Odoo的装饰器来定义新的方法,以确保您的代码可以与任何未来的Odoo版本兼容。