forked from openlp/openlp
olpv1 bible importer
This commit is contained in:
parent
586d2bda4e
commit
e6cfad921a
@ -231,7 +231,7 @@ class BibleDB(QtCore.QObject, Manager):
|
||||
|
||||
def create_chapter(self, book_id, chapter, textlist):
|
||||
"""
|
||||
Add a chapter and it's verses to a book.
|
||||
Add a chapter and its verses to a book.
|
||||
|
||||
``book_id``
|
||||
The id of the book being appended.
|
||||
|
@ -61,6 +61,7 @@ class BibleFormat(object):
|
||||
CSV = 1
|
||||
OpenSong = 2
|
||||
WebDownload = 3
|
||||
OpenLPv1 = 4
|
||||
|
||||
@staticmethod
|
||||
def get_class(format):
|
||||
|
98
openlp/plugins/bibles/lib/olp1import.py
Executable file
98
openlp/plugins/bibles/lib/olp1import.py
Executable file
@ -0,0 +1,98 @@
|
||||
# -*- coding: utf-8 -*-
|
||||
# vim: autoindent shiftwidth=4 expandtab textwidth=80 tabstop=4 softtabstop=4
|
||||
|
||||
###############################################################################
|
||||
# OpenLP - Open Source Lyrics Projection #
|
||||
# --------------------------------------------------------------------------- #
|
||||
# Copyright (c) 2008-2010 Raoul Snyman #
|
||||
# Portions copyright (c) 2008-2010 Tim Bentley, Jonathan Corwin, Michael #
|
||||
# Gorven, Scott Guerrieri, Meinert Jordan, Andreas Preikschat, Christian #
|
||||
# Richter, Philip Ridout, Maikel Stuivenberg, Martin Thompson, Jon Tibble, #
|
||||
# Carsten Tinggaard, Frode Woldsund #
|
||||
# --------------------------------------------------------------------------- #
|
||||
# This program 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; version 2 of the License. #
|
||||
# #
|
||||
# This program 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 this program; if not, write to the Free Software Foundation, Inc., 59 #
|
||||
# Temple Place, Suite 330, Boston, MA 02111-1307 USA #
|
||||
###############################################################################
|
||||
|
||||
import logging
|
||||
import sqlite
|
||||
|
||||
#from openlp.core.lib import Receiver
|
||||
from db import BibleDB
|
||||
|
||||
log = logging.getLogger(__name__)
|
||||
|
||||
class OpenLPv1BibleImporter(BibleDB):
|
||||
"""
|
||||
This class provides the OpenLPv1 bible importer.
|
||||
"""
|
||||
def _init__(self, parent, **kwargs):
|
||||
"""
|
||||
Constructor.
|
||||
"""
|
||||
BibleDB.__init__(self, parent, **kwargs)
|
||||
if 'filename' not in kwargs:
|
||||
raise KeyError(u'You have to supply a file name to import from.')
|
||||
self.filename = kwargs['filename']
|
||||
# QtCore.QObject.connect(Receiver.get_receiver(),
|
||||
# QtCore.SIGNAL(u'bibles_stop_import'), self.stop_import)
|
||||
|
||||
def do_import(self):
|
||||
"""
|
||||
Imports an openlp.org v1 bible.
|
||||
"""
|
||||
connection = None
|
||||
cursor = None
|
||||
#self.wizard.incrementProgressBar(u'Preparing for import...')
|
||||
try:
|
||||
connection = sqlite.connect(self.filename)
|
||||
cursor = connection.cursor()
|
||||
except:
|
||||
return False
|
||||
# Import the meta data.
|
||||
cursor.execute(u'SELECT "key", "value" FROM metadata')
|
||||
meta_data = cursor.fetchall()
|
||||
for data in meta_data:
|
||||
key = unicode(data[0], u'cp1252')
|
||||
value = unicode(data[1], u'cp1252')
|
||||
if key == u'Permission':
|
||||
key = u'Permissions'
|
||||
self.create_meta(self, key, value)
|
||||
# Import the testaments.
|
||||
cursor.execute(u'SELECT id, name FROM testament')
|
||||
testaments = cursor.fetchall()
|
||||
for testament in testaments:
|
||||
id = int(testament[0])
|
||||
name = unicode(testament[1], u'cp1252')
|
||||
sql_params = (id, name)
|
||||
# TODO: complete testament import.
|
||||
# Import books.
|
||||
cursor.execute(u'SELECT id, testament_id, name, abbreviation FROM book')
|
||||
books = cursor.fetchall()
|
||||
for book in books:
|
||||
testament_id = int(book[1])
|
||||
name = unicode(book[2], u'cp1252')
|
||||
abbreviation = unicode(book[3], u'cp1252')
|
||||
self.create_book(name, abbreviation, testament_id)
|
||||
# Import chapters/verses.
|
||||
cursor.execute(u'SELECT id, book_id, chapter, verse, text || \'\' AS '
|
||||
'text FROM verse')
|
||||
verses = old_cursor.fetchall()
|
||||
for verse in verses:
|
||||
book_id = int(verse[1])
|
||||
chapter = int(verse[2])
|
||||
verse_number = int(verse[3])
|
||||
text = unicode(verse[4], u'cp1252')
|
||||
self.create_verse(book_id, chapter, verse_number, text)
|
||||
return True
|
||||
|
Loading…
Reference in New Issue
Block a user