Zrušen unicodecsv.py, opraven Soustřeďkový export účastníků
This commit is contained in:
		
							parent
							
								
									f4e14caed4
								
							
						
					
					
						commit
						fb40de121f
					
				
					 2 changed files with 3 additions and 65 deletions
				
			
		|  | @ -1,62 +0,0 @@ | ||||||
| import csv, codecs |  | ||||||
| from io import StringIO |  | ||||||
| 
 |  | ||||||
| class UTF8Recoder: |  | ||||||
|     """ |  | ||||||
|     Iterator that reads an encoded stream and reencodes the input to UTF-8 |  | ||||||
|     """ |  | ||||||
|     def __init__(self, f, encoding): |  | ||||||
|         self.reader = codecs.getreader(encoding)(f) |  | ||||||
| 
 |  | ||||||
|     def __iter__(self): |  | ||||||
|         return self |  | ||||||
| 
 |  | ||||||
|     def next(self): |  | ||||||
|         return self.reader.next().encode("utf-8") |  | ||||||
| 
 |  | ||||||
| class UnicodeReader: |  | ||||||
|     """ |  | ||||||
|     A CSV reader which will iterate over lines in the CSV file "f", |  | ||||||
|     which is encoded in the given encoding. |  | ||||||
|     """ |  | ||||||
| 
 |  | ||||||
|     def __init__(self, f, dialect=csv.excel, encoding="utf-8", **kwds): |  | ||||||
|         f = UTF8Recoder(f, encoding) |  | ||||||
|         self.reader = csv.reader(f, dialect=dialect, **kwds) |  | ||||||
| 
 |  | ||||||
|     def next(self): |  | ||||||
|         row = self.reader.next() |  | ||||||
|         return [unicode(s, "utf-8") for s in row] |  | ||||||
| 
 |  | ||||||
|     def __iter__(self): |  | ||||||
|         return self |  | ||||||
| 
 |  | ||||||
| class UnicodeWriter: |  | ||||||
|     """ |  | ||||||
|     A CSV writer which will write rows to CSV file "f", |  | ||||||
|     which is encoded in the given encoding. |  | ||||||
|     """ |  | ||||||
| 
 |  | ||||||
|     def __init__(self, f, dialect=csv.excel, encoding="utf-8", **kwds): |  | ||||||
|         # Redirect output to a queue |  | ||||||
|         self.queue = cStringIO.StringIO() |  | ||||||
|         self.writer = csv.writer(self.queue, dialect=dialect, **kwds) |  | ||||||
|         self.stream = f |  | ||||||
|         self.encoder = codecs.getincrementalencoder(encoding)() |  | ||||||
| 
 |  | ||||||
|     def writerow(self, row): |  | ||||||
|         self.writer.writerow([s.encode("utf-8") for s in row]) |  | ||||||
|         # Fetch UTF-8 output from the queue ... |  | ||||||
|         data = self.queue.getvalue() |  | ||||||
|         data = data.decode("utf-8") |  | ||||||
|         # ... and reencode it into the target encoding |  | ||||||
|         data = self.encoder.encode(data) |  | ||||||
|         # write to the target stream |  | ||||||
|         self.stream.write(data) |  | ||||||
|         # empty queue |  | ||||||
|         self.queue.truncate(0) |  | ||||||
| 
 |  | ||||||
|     def writerows(self, rows): |  | ||||||
|         for row in rows: |  | ||||||
|             self.writerow(row) |  | ||||||
| 
 |  | ||||||
|  | @ -20,7 +20,6 @@ import seminar.models as s | ||||||
| from seminar.models import Problem, Cislo, Reseni, Nastaveni, Rocnik, Soustredeni, Organizator, Resitel, Novinky, Soustredeni_Ucastnici, Pohadka, Tema, Clanek, Osoba, Skola # Tohle je stare a chceme se toho zbavit. Pouzivejte s.ToCoChci | from seminar.models import Problem, Cislo, Reseni, Nastaveni, Rocnik, Soustredeni, Organizator, Resitel, Novinky, Soustredeni_Ucastnici, Pohadka, Tema, Clanek, Osoba, Skola # Tohle je stare a chceme se toho zbavit. Pouzivejte s.ToCoChci | ||||||
| #from .models import VysledkyZaCislo, VysledkyKCisluZaRocnik, VysledkyKCisluOdjakziva | #from .models import VysledkyZaCislo, VysledkyKCisluZaRocnik, VysledkyKCisluOdjakziva | ||||||
| from seminar import utils,treelib | from seminar import utils,treelib | ||||||
| from .unicodecsv import UnicodeWriter |  | ||||||
| from seminar.forms import PrihlaskaForm, LoginForm, ProfileEditForm | from seminar.forms import PrihlaskaForm, LoginForm, ProfileEditForm | ||||||
| import seminar.forms as f | import seminar.forms as f | ||||||
| 
 | 
 | ||||||
|  | @ -955,10 +954,11 @@ def soustredeniUcastniciExportView(request,soustredeni): | ||||||
| 	response = HttpResponse(content_type='text/csv') | 	response = HttpResponse(content_type='text/csv') | ||||||
| 	response['Content-Disposition'] = 'attachment; filename="ucastnici.csv"' | 	response['Content-Disposition'] = 'attachment; filename="ucastnici.csv"' | ||||||
| 
 | 
 | ||||||
| 	writer = UnicodeWriter(response) | 	writer = csv.writer(response) | ||||||
| 	writer.writerow(["jmeno", "prijmeni", "rok_maturity", "telefon", "email", "ulice", "mesto", "psc","stat"]) | 	writer.writerow(["jmeno", "prijmeni", "rok_maturity", "telefon", "email", "ulice", "mesto", "psc","stat"]) | ||||||
| 	for u in ucastnici: | 	for u in ucastnici: | ||||||
| 		writer.writerow([u.jmeno, u.prijmeni, str(u.rok_maturity), u.telefon, u.email, u.ulice, u.mesto, u.psc, u.stat.name]) | 		o = u.osoba | ||||||
|  | 		writer.writerow([o.jmeno, o.prijmeni, str(u.rok_maturity), o.telefon, o.email, o.ulice, o.mesto, o.psc, o.stat.name]) | ||||||
| 	return response | 	return response | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
		Loading…
	
		Reference in a new issue
	
	 Pavel 'LEdoian' Turinsky
						Pavel 'LEdoian' Turinsky