|
1
2
3
4
5
6
7
8
9
10
11
12
|
#-*- coding:utf-8 -*-
import codecs
import datetime
import HTMLParser
import os
import tarfile
from django.core.management.base import BaseCommand
from django.template.loader import render_to_string
from django.utils.encoding import smart_str
|
|
13
|
from dictionary.models import Lemma, WalentyStat, get_ready_statuses
|
|
14
15
16
|
from settings import WALENTY_PATH
class Command(BaseCommand):
|
|
17
18
|
args = '<dict dict ...>'
help = 'Get Walenty in TeX format.'
|
|
19
20
21
22
|
def handle(self, *args, **options):
try:
now = datetime.datetime.now().strftime('%Y%m%d')
|
|
23
24
25
26
27
28
29
30
|
vocab_names = list(args)
vocab_names.sort()
if vocab_names:
filename_base = '%s_%s_%s' % ('walenty', '+'.join(vocab_names), now)
else:
filename_base = '%s_%s' % ('walenty', now)
|
|
31
32
33
34
|
base_path = os.path.join(WALENTY_PATH, filename_base)
outpath = base_path + '.tex'
ready_statuses = get_ready_statuses()
lemmas = Lemma.objects.filter(old=False)
|
|
35
36
37
38
|
if vocab_names:
lemmas = lemmas.filter(vocabulary__name__in=vocab_names)
|
|
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
|
ready_lemmas = lemmas.filter(status__in=ready_statuses).order_by('entry_obj__name')
write_tex_walenty(outpath, ready_lemmas)
archive = tarfile.open(base_path + '-tex.tar.gz', 'w:gz')
os.chdir(WALENTY_PATH)
archive.add(os.path.basename(outpath))
finally:
archive.close()
os.remove(outpath)
def write_tex_walenty(outpath, lemmas):
try:
outfile = codecs.open(outpath, 'w')
h = HTMLParser.HTMLParser()
outfile.write(smart_str(h.unescape(render_to_string('tex/slowal.tex', {'lemmas': lemmas,
'q_frame_opinions': [],
|
|
55
56
57
58
|
'download_dict' : {'frame_opinions': []},
'frames_count' : WalentyStat.objects.get(label=u'Łączna liczba ram semantycznych').value,
'schemata_count' : WalentyStat.objects.get(label=u'Łączna liczba schematów').value,
'lemmata_count' : WalentyStat.objects.get(label=u'Łączna liczba haseł').value}))))
|
|
59
60
|
finally:
outfile.close()
|