如何在Python中在运行时向外部类添加方法?

时间:2017-03-27 18:27:46

标签: python python-2.7 python-3.x methods

PyGithub似乎不支持GitHub API call to acquire the latest release。我想知道我是否可以在运行时向PyGithub添加一个方法来为我做这个。

例如,现有代码具有以下方法:

# Repository.py
def get_releases(self):
    """
    :calls: `GET /repos/:owner/:repo/releases <http://developer.github.com/v3/repos>`_
    :rtype: :class:`github.PaginatedList.PaginatedList` of :class:`github.Tag.Tag`
    """
    return github.PaginatedList.PaginatedList(
        github.GitRelease.GitRelease,
        self._requester,
        self.url + "/releases",
        None
    )

我想将这个添加到Repository.py类:

def get_latest_release(self):
    return github.PaginatedList.PaginatedList(
        github.GitRelease.GitRelease,
        self._requester,
        self.url + "/releases/latest",
        None
    )

我试过了,但收到了一个错误:

# main.py

from types import MethodType
from github import Github
from github.Repository import Repository, github

def get_latest_release(self): ...

def main():
    Repository.method = MethodType(get_latest_release, None, Repository)
    g = Github(<my name>, <my password>)
    org = g.get_organization(<name of org>)
    repo = org.get_repo(<name of repository>)
    release = repo.get_latest_release()

    # AttributeError: 'Repository' object has no attribute 'get_latest_release'

是否可以在运行时添加此方法?

1 个答案:

答案 0 :(得分:2)

直接分配给Repository.get_latest_release应该是系数,例如:

Repository.get_latest_release = get_latest_release

如果您尝试分配给某个实例,则只需要MethodType,例如

>>> import types
>>> class A(object):
...     pass
>>> a = A()
>>> A.one = lambda self: 1
>>> a.two = types.MethodType(lambda self: 2, a)
>>> a.one(), a.two()
(1, 2)

class分配可用于该类的所有实例,instance分配不是:

>>> b = A()
>>> b.one()
1
>>> b.two()
AttributeError: 'A' object has no attribute 'two'