-
Data: 2009-07-02 20:40:04
Temat: Re: Python: pliki tekstowe - różne kodowanie
Od: Rob Wolfe <r...@s...pl> szukaj wiadomości tego autora
[ pokaż wszystkie nagłówki ]Zbigniew Zagórski <z...@g...com> writes:
> On 2 Lip, 14:01, "didi" <d...@d...com> wrote:
>> Użytkownik "didi" <d...@d...com> napisał w
wiadomościnews:h2hvke$456$1@news.wp.pl...
>>
>> > outfile=open("name.txt",'w')
>> > for file in filenames:
>> > text=open(file)
>> > lines=text.readlines()
>> > outfile.writelines(lines[3:]) #zapisz wszystkie linie począwszy od
>> > 3-ciej
>> > text.close
>> > outfile.close
>>
>> > I problem jaki napotkałem to UnicodeDecodeError: 'charmap' codec can't
>> > decode byte ... in position ...:character mapt to <undifined>
>>
>> Zamiast Pythona 3xx użyłem wersję 2xx, które z defaultu nie konwertuje do
>> postaci Unicode.
>
> Oj wygląda na to, że Python zmierza w złym kierunku ... Szkoda.
Taki wielgachny wnioch na podstawie tak drobnego nieporozumienia? ;)
> Przeczytałem twój post jakiś czas temu i zastanawiałem się jak to
> możliwe...
> 100 razy pisałem coś podobnego i działało.
>
> A tu okazuje się, że dla Pythona NG wszystko to tekst. Brawo... No i
> brawo
No chyba po to wymyślono dwa tryby otwarcia pliku:
1. tekstowy - do czytania właśnie *tekstu*
2. binarny - do czytania bajtów
> za stabilne API ... a właśnie przymierzałem się do sprawdzenia py3k,
> odłożę
> na nigdy.
Masz na myśli stabilne API pomiędzy 2.x i 3.x?
Cały sens powstania wersji 3.x sprowadza się do tego,
aby nie być zmuszonym wstecznej kompatybilności z 2.x.
Akurat w kwestii I/O i "bajty vs stringi vs unicode" w 3.x nastąpiły
bardzo znaczące zmiany:
http://docs.python.org/3.1/whatsnew/3.0.html#text-vs
-data-instead-of-unicode-vs-8-bit
Aczkolwiek nie jakieś znowu rewolucyjne. Model bardzo zbliżony do java'owego.
W tym konkretnym przypadku, który doprowadził Cię do tak drastycznych
wniosków wystarczyło zamiast:
open(file)
napisać:
open(file, errors='replace')
co jest napisane wołami w dokumentacji.
Java różni się tym, że przy błędnym kodowaniu nie rzuca wyjątku,
lecz traktuje taką sytuację jako niezdefiniowaną.
Python dodaje tu dodatkową możliwość kontroli i jeszcze zbiera
za to cięgi. Echhh... ;)
RW
Następne wpisy z tego wątku
- 03.07.09 07:30 Zbigniew Zagórski
Najnowsze wątki z tej grupy
- Do czego nadaje się QDockWidget z bibl. Qt?
- Bibl. Qt jest sztucznie ograniczona - jest nieprzydatna do celów komercyjnych
- Co sciaga kretynow
- AEiC 2024 - Ada-Europe conference - Deadlines Approaching
- Jakie są dobre zasady programowania programów opartych na wtyczkach?
- sprawdzanie słów kluczowych dot. zła
- Re: W czym sie teraz pisze programy??
- Re: (PDF) Surgical Pathology of Non-neoplastic Gastrointestinal Diseases by Lizhi Zhang
- CfC 28th Ada-Europe Int. Conf. Reliable Software Technologies
- Młodzi programiści i tajna policja
- Ada 2022 Language Reference Manual to be Published by Springer
- Press Release - AEiC 2023, Ada-Europe Reliable Softw. Technol.
- Ada-Europe - AEiC 2023 early registration deadline approaching
- Ada-Europe Int.Conf. Reliable Software Technologies, AEiC 2023
- Ile cykli zajmuje mnożenie liczb 64-bitowych?
Najnowsze wątki
- 2024-05-26 O co chodzi?
- 2024-05-26 PJ autobus-tramwaj
- 2024-05-26 Renault Trafic i lampka z czerwonym STOP
- 2024-05-26 cena pięciocyfrowa
- 2024-05-26 Re: Jak dobra KE "okrada" złą Rosję "dla Ukrainy"
- 2024-05-25 supercap
- 2024-05-25 Sulzbach => Technischer Rollouter (d/m/w) <=
- 2024-05-25 Warszawa => Senior Account Manager <=
- 2024-05-25 Warszawa => Mid PHP Developer (Laravel) <=
- 2024-05-25 Warszawa => Mid PHP Developer (Laravel) <=
- 2024-05-25 Warszawa => Interactive/Experience Designer <=
- 2024-05-25 Warszawa => Key Account Manager <=
- 2024-05-25 Warszawa => SAP WM Consultant / Execution <=
- 2024-05-25 Warszawa => Key Account Manager <=
- 2024-05-25 Re: znów ten wrocław