Coverage for modules/org/openteacher/logic/loaders/abbyy/abbyy : 87%
Hot-keys on this page
r m x p toggle line displays
j k next/prev highlighted chunk
0 (zero) top of page
1 (one) first highlighted chunk
|
#! /usr/bin/env python3 # -*- coding: utf-8 -*-
# Copyright 2011-2013, Marten de Vries # # This file is part of OpenTeacher. # # OpenTeacher is free software: you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by # the Free Software Foundation, either version 3 of the License, or # (at your option) any later version. # # OpenTeacher is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU General Public License for more details. # # You should have received a copy of the GNU General Public License # along with OpenTeacher. If not, see <http://www.gnu.org/licenses/>.
"""Loads ABBYY Lingvo Tutor files (.xml)"""
"default": 756, }
self._mm.mods(type="wordsStringParser"), ) self._mm.mods(type="translator"), )
except IndexError: _, ngettext = str, lambda a, b, n: a if n == 1 else b else: self._mm.resourcePath("translations") ) #TRANSLATORS: This is the name of a file format OT can read.
except IndexError: pass else:
#No mimetype. Claiming .xml is too harsh.
"items": list(), "title": root.get("title", u""), }
#a counter is used to suppply the ids. That's because ABBYY #Lingvo Tutor decided to not include ids anymore from version X5 #on.
{ "id": next(counter), "questions": wsp.parse(wordTree.findtext("word") or u""), "answers": [[a.text or u"" for a in wordTree.findall("meanings/meaning/translations/word")]], "commentAfterAnswering": u", ".join( e.text or u"" for e in wordTree.findall("meanings/meaning/examples/example") ) } for wordTree in root.findall("card") ]
"resources": {}, "list": wordList, }
|