sollten Sie verwenden %x
und %X
die Datumszeichenfolge in der richtigen locale zu formatieren. Z.B. auf Schwedisch wird ein Datum als 2014-11-14
anstelle von 11/14/2014
dargestellt.
Der richtige Weg, um das Ergebnis zu erhalten, wie Unicode ist:
locale.setlocale(locale.LC_ALL, lang)
format_ = datetime.datetime.today().strftime('%a, %x %X')
format_u = format_.decode(locale.getlocale()[1])
Hier ist das Ergebnis von mehreren Sprachen:
Bulgarian пет, 14.11.2014 г. 11:21:10 ч.
Czech pá, 14.11.2014 11:21:10
Danish fr, 14-11-2014 11:21:10
German Fr, 14.11.2014 11:21:10
Greek Παρ, 14/11/2014 11:21:10 πμ
English Fri, 11/14/2014 11:21:10 AM
Spanish vie, 14/11/2014 11:21:10
Estonian R, 14.11.2014 11:21:10
Finnish pe, 14.11.2014 11:21:10
French ven., 14/11/2014 11:21:10
Croatian pet, 14.11.2014. 11:21:10
Hungarian P, 2014.11.14. 11:21:10
Italian ven, 14/11/2014 11:21:10
Lithuanian Pn, 2014.11.14 11:21:10
Latvian pk, 2014.11.14. 11:21:10
Dutch vr, 14-11-2014 11:21:10
Norwegian fr, 14.11.2014 11:21:10
Polish Pt, 2014-11-14 11:21:10
Portuguese sex, 14/11/2014 11:21:10
Romanian V, 14.11.2014 11:21:10
Russian Пт, 14.11.2014 11:21:10
Slovak pi, 14. 11. 2014 11:21:10
Slovenian pet, 14.11.2014 11:21:10
Swedish fr, 2014-11-14 11:21:10
Turkish Cum, 14.11.2014 11:21:10
Chinese 周五, 2014/11/14 11:21:10
BTW wird es nicht unter Windows arbeiten. Überprüfen Sie dies: http://stackoverflow.com/questions/955986/what-is-the-correct-way-to-set-pythons-locale/956084#956084 – uolot
Es erfordert auch den Computer, auf dem Sie dies ausführen, um das Gebietsschema zu haben Sie versuchen, generated zu verwenden. Auf GNU/Linux-Systemen zeigt locale -a die Liste der verfügbaren Ländereinstellungen an. Die Schritte zum Hinzufügen neuer Gebietsschemata unterscheiden sich je nach Distros. –
Es wird abgeraten, das lokalisierte Format von Datum/Uhrzeit durch ** Änderung des Gebiets zu erhalten **. Siehe meine Antwort für die richtige Lösung. –