當前位置: 首頁>>代碼示例>>Python>>正文


Python AniDBMaper.getAnimeCodesA方法代碼示例

本文整理匯總了Python中aniDBmaper.AniDBMaper.getAnimeCodesA方法的典型用法代碼示例。如果您正苦於以下問題:Python AniDBMaper.getAnimeCodesA方法的具體用法?Python AniDBMaper.getAnimeCodesA怎麽用?Python AniDBMaper.getAnimeCodesA使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在aniDBmaper.AniDBMaper的用法示例。


在下文中一共展示了AniDBMaper.getAnimeCodesA方法的2個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: Anime

# 需要導入模塊: from aniDBmaper import AniDBMaper [as 別名]
# 或者: from aniDBmaper.AniDBMaper import getAnimeCodesA [as 別名]
class Anime(aniDBabstractObject):
    def __init__(self, aniDB, name=None, aid=None, tvdbid=None, paramsA=None, autoCorrectName=False, load=False):

        self.maper = AniDBMaper()
        self.tvDBMap = TvDBMap()
        self.allAnimeXML = None

        self.name = name
        self.aid = aid
        self.tvdb_id = tvdbid

        if self.tvdb_id and not self.aid:
            self.aid = self.tvDBMap.get_anidb_for_tvdb(self.tvdb_id)

        if not (self.name or self.aid):
            raise AniDBIncorrectParameterError("No aid or name available")

        if not self.aid:
            self.aid = self._get_aid_from_xml(self.name)
        if not self.name or autoCorrectName:
            self.name = self._get_name_from_xml(self.aid)

        if not (self.name or self.aid):
            raise ValueError

        if not self.tvdb_id:
            self.tvdb_id = self.tvDBMap.get_tvdb_for_anidb(self.aid)

        if not paramsA:
            self.bitCode = "b2f0e0fc000000"
            self.params = self.maper.getAnimeCodesA(self.bitCode)
        else:
            self.paramsA = paramsA
            self.bitCode = self.maper.getAnimeBitsA(self.paramsA)

        super(Anime, self).__init__(aniDB, load)

    def load_data(self):
        """load the data from anidb"""

        if not (self.name or self.aid):
            raise ValueError

        self.rawData = self.aniDB.anime(aid=self.aid, aname=self.name, amask=self.bitCode)
        if self.rawData.datalines:
            self._fill(self.rawData.datalines[0])
            self._builPreSequal()
            self.laoded = True

    def get_groups(self):
        if not self.aid:
            return []
        self.rawData = self.aniDB.groupstatus(aid=self.aid)
        self.release_groups = []
        for line in self.rawData.datalines:
            self.release_groups.append({"name":unicode(line["name"], "utf-8"),
                                        "rating":line["rating"],
                                        "range":line["episode_range"]
                                        })
        return self.release_groups

    #TODO: refactor and use the new functions in anidbFileinfo
    def _get_aid_from_xml(self, name):
        if not self.allAnimeXML:
            self.allAnimeXML = self._read_animetitels_xml()

        regex = re.compile('( \(\d{4}\))|[%s]' % re.escape(string.punctuation)) # remove any punctuation and e.g. ' (2011)'
        #regex = re.compile('[%s]'  % re.escape(string.punctuation)) # remove any punctuation and e.g. ' (2011)'
        name = regex.sub('', name.lower())
        lastAid = 0
        for element in self.allAnimeXML.getiterator():
            if element.get("aid", False):
                lastAid = int(element.get("aid"))
            if element.text:
                testname = regex.sub('', element.text.lower())

                if testname == name:
                    return lastAid
        return 0

    #TODO: refactor and use the new functions in anidbFileinfo
    def _get_name_from_xml(self, aid, onlyMain=True):
        if not self.allAnimeXML:
            self.allAnimeXML = self._read_animetitels_xml()

        for anime in self.allAnimeXML.findall("anime"):
            if int(anime.get("aid", False)) == aid:
                for title in anime.getiterator():
                    currentLang = title.get("{http://www.w3.org/XML/1998/namespace}lang", False)
                    currentType = title.get("type", False)
                    if (currentLang == "en" and not onlyMain) or currentType == "main":
                        return title.text
        return ""


    def _read_animetitels_xml(self, path=None):
        if not path:
            path = os.path.join(os.path.dirname(os.path.abspath(__file__)), "animetitles.xml")

        f = open(path, "r")
#.........這裏部分代碼省略.........
開發者ID:MeesterCor,項目名稱:SickRage,代碼行數:103,代碼來源:aniDBAbstracter.py

示例2: Anime

# 需要導入模塊: from aniDBmaper import AniDBMaper [as 別名]
# 或者: from aniDBmaper.AniDBMaper import getAnimeCodesA [as 別名]
class Anime(aniDBabstractObject):
    def __init__(self, aniDB, name=None, aid=None, paramsA=None, autoCorrectName=False, load=False):

        self.maper = AniDBMaper()
        self.allAnimeXML = None

        self.name = name
        self.aid = aid

        if not (self.name or self.aid):
            raise AniDBIncorrectParameterError("No aid or name available")

        if not (self.name or self.aid):
            raise ValueError

        if not paramsA:
            self.bitCode = "b2f0e0fc000000"
            self.params = self.maper.getAnimeCodesA(self.bitCode)
        else:
            self.paramsA = paramsA
            self.bitCode = self.maper.getAnimeBitsA(self.paramsA)

        aniDBabstractObject.__init__(self, aniDB, load)

    def load_data(self):
        """load the data from anidb"""

        if not (self.name or self.aid):
            raise ValueError

        self.rawData = self.aniDB.anime(aid=self.aid, aname=self.name, amask=self.bitCode)
        if self.rawData.datalines:
            self.fill(self.rawData.datalines[0])
            self.builPreSequal()
            self.loaded = True

    def get_groups(self):
        if not self.aid:
            return []
        self.rawData = self.aniDB.groupstatus(aid=self.aid)
        self.release_groups = []
        for line in self.rawData.datalines:
            self.release_groups.append({"name":unicode(line["name"], "utf-8"),
                                        "rating":line["rating"],
                                        "range":line["episode_range"]
                                        })
        return self.release_groups

    def builPreSequal(self):
        if self.dataDict.has_key('related_aid_list') and self.dataDict.has_key('related_aid_type'):
            try:
                for i in range(len(self.related_aid_list)):
                    if self.related_aid_type[i] == 2:
                        self.dataDict["prequal"] = self.dataDict['related_aid_list'][i]
                    elif self.related_aid_type[i] == 1:
                        self.dataDict["sequal"] = self.dataDict['related_aid_list'][i]
            except:
                if self.related_aid_type == 2:
                    self.dataDict["prequal"] = self.dataDict['related_aid_list']
                elif self.str_related_aid_type == 1:
                    self.dataDict["sequal"] = self.dataDict['related_aid_list']
開發者ID:Forkk,項目名稱:nixconf,代碼行數:63,代碼來源:aniDBAbstracter.py


注:本文中的aniDBmaper.AniDBMaper.getAnimeCodesA方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。