Ovvpfile: protřídění mrtvého kódu
Jestli jsem to rozbil, tak to revertněte. Ale myslím, že jsem fakt smazal jen kód, který nemohl jít spustit…
This commit is contained in:
parent
5e07412d92
commit
0f381a7529
1 changed files with 4 additions and 55 deletions
|
@ -1,13 +1,8 @@
|
|||
# -*- coding: utf-8 -*-
|
||||
|
||||
try:
|
||||
from django.http import HttpResponse
|
||||
from django.utils.encoding import force_text
|
||||
except:
|
||||
force_text = str
|
||||
from django.http import HttpResponse
|
||||
from django.utils.encoding import force_text
|
||||
|
||||
|
||||
class OvvpFile(object):
|
||||
class OvvpFile:
|
||||
def __init__(self):
|
||||
# { header: value, ... }
|
||||
self.headers = {}
|
||||
|
@ -30,52 +25,6 @@ class OvvpFile(object):
|
|||
def to_string(self):
|
||||
return ''.join(self.to_lines())
|
||||
|
||||
# Pozn: tohle je ta jediná funkce, která se reálně používá…
|
||||
def to_HttpResponse(self):
|
||||
return HttpResponse(self.to_string(), content_type='text/plain; charset=utf-8')
|
||||
|
||||
def parse_from(self, source, with_headers=True):
|
||||
"Parse data from file, string or line iterator, overwriting self"
|
||||
if isinstance(source, str) or isinstance(source, unicode):
|
||||
return self.parse_from(source.split('\n'))
|
||||
|
||||
it = iter(source)
|
||||
|
||||
# header
|
||||
self.headers = {}
|
||||
if with_headers:
|
||||
for r in it:
|
||||
if isinstance(r, str):
|
||||
r = r.decode('utf8')
|
||||
assert isinstance(r, unicode)
|
||||
r = r.rstrip('\n')
|
||||
if r == u"":
|
||||
break
|
||||
k, v = r.split(u'\t', 1)
|
||||
self.headers[k] = v
|
||||
|
||||
# columns
|
||||
r = it.next()
|
||||
if isinstance(r, str):
|
||||
r = r.decode('utf8')
|
||||
self.columns = [cn.strip() for cn in r.split(u'\t') if cn.strip() != ""]
|
||||
|
||||
# rows
|
||||
self.rows = []
|
||||
for r in it:
|
||||
if isinstance(r, str):
|
||||
r = r.decode('utf8')
|
||||
r = r.rstrip('\n')
|
||||
if not r:
|
||||
break
|
||||
rtup = r.split(u'\t')
|
||||
rdict = {}
|
||||
for ci in range(len(self.columns)):
|
||||
rdict[self.columns[ci]] = rtup[ci]
|
||||
self.rows.append(rdict)
|
||||
|
||||
|
||||
|
||||
def parse(source, with_headers=True):
|
||||
o = OvvpFile()
|
||||
o.parse_from(source, with_headers=with_headers)
|
||||
return o
|
||||
|
|
Loading…
Reference in a new issue