On 07. 12. 21 21:33, Dusan Gazo wrote:
Zdravim.

Som začiatočník a skúšam možnosti jazyka.

Prečo pri otvorenom súbore v textovom móde, funkcia seek(x, y) je funkčná len ak je y =  0 a x >= 0?  Pri Y = 1 alebo 2 môže byt x len 0.

Je na to nejaký dôvod?  Ak otvorim súbor binárne tak funkcia pracuje tak, ako si predstavujem, t.j. Y = 0 -> x môže byť >= 0 ,

Y = 1 ->  x  môže byť < >= 0 , Y=2  x môže byť <=0.


Do soouboru se neukladaji znaky, ale bajty. Text se da prevest (zakodovat) na bajty, bajty se daji dekodovat zpatky, ale problem je ze jeden znak muze byt zakodovany ruznym poctem bajtu:

>>> len('a'.encode('utf-8'))
1
>>> len('ů'.encode('utf-8'))
2
>>> len('←'.encode('utf-8'))
3
>>> len('😸'.encode('utf-8'))
4

Python nemuze operacnimu systemu rict "skoc o 400 znaku dal", jen napr. "skoc o 400 bajtu dal". Ale na to, aby spocital kolik bajtu tyhle znaky zaberou by je musel vechny nacist a zpracovat.

Mimochodem, pro Y=0 (whence=SEEK_SET) nemuze byt X jakekoli cislo, ale jen cislo ktere jsi predtim dostal pomoci metody tell(). S jinym cislem bys mohl "pristat" v pulce znaku, a kdo vi co by se delo pak...

Viz dokumentace: https://docs.python.org/3/library/io.html#io.TextIOBase.seek


Jestli chces skakat dopredu, muzes pouzit read() a dany pocet znaku nacist a zahodit. (Pozor, cti dokumentaci: read() muze vatit kratsi retezec nez o jaky si reknes.)
Jestli chces skakat na pozici kde jsi uz byl, zapamatuj si ji pomoci tell().
A nebo otevri soubor v binarnim modu a dekodovani na text res sam.
_______________________________________________
Python mailing list
python@py.cz
http://www.py.cz/mailman/listinfo/python

Visit: http://www.py.cz

Odpovedet emailem