Seite 1 von 1

textformat

Verfasst: Freitag 27. Oktober 2006, 23:21
von Jerala
Hallo zusammen!

Bin Anfänger und muss in mein file eine sequenz einfügen, die Daten in einer bestimmten Form ins excel schreibt, also statt . als dezimalzeichen ein komma und nach jeden tabstop eine neue spalte anfängt und so.

Kann mir einer weiterhelfen welche befehle ich dafür benutzen muss? Hab zwar ein Python-Buch, aber da sowas konkretes nicht gefunden.

Dank im Voraus!

Verfasst: Samstag 28. Oktober 2006, 03:49
von Mr_Snede
Hier bietet sich das Modul csv (Comma(können auch andere Trennzeichen sein) Seperated Values) an.

Such mal hier im Forum danach.

Das Trennzeichen kann über den Parameter delimiter = ";" eingestellt werden.

Verfasst: Samstag 28. Oktober 2006, 11:03
von Jerala
Sorry, aber hab da im forum nichts gefunden, was ich gebrauchen kann. Ich habe also eine .txt-Datei, in der die Zahlen so stehen:

-152.6E-09 -150.6E-09 -152.7E-09 -152.2E-09 -151.0E-

Das Ganze muss grob ja so aussehen:

ich muss erst den Befehl:
file=...txt
Datei=open(file,'r')
lines=Datei.readlines()
Datei.close

--hier muss jetzt was eingegeben werden---
wo kommt denn hier jetzt "delimiter" hin?-hab diesem Ausdruck in meinen unterlagen nicht.WElche Struktur hat das ganze?

und dann halt der write-Befehl

HILFE!? ist dringend

Verfasst: Samstag 28. Oktober 2006, 11:24
von murph

Verfasst: Samstag 28. Oktober 2006, 11:29
von BlackJack
Jerala hat geschrieben:Ich habe also eine .txt-Datei, in der die Zahlen so stehen:

-152.6E-09 -150.6E-09 -152.7E-09 -152.2E-09 -151.0E-
So eine Zeile kannst Du, wenn sie als Zeichenkette vorliegt, mit der `split()` Methode zerlegen:

Code: Alles auswählen

In [14]: line = '-152.6E-09 -150.6E-09 -152.7E-09 -152.2E-09'

In [15]: line.split()
Out[15]: ['-152.6E-09', '-150.6E-09', '-152.7E-09', '-152.2E-09']
Das Ganze muss grob ja so aussehen:

ich muss erst den Befehl:
file=...txt
Datei=open(file,'r')
lines=Datei.readlines()
Datei.close

--hier muss jetzt was eingegeben werden---
wo kommt denn hier jetzt "delimiter" hin?-hab diesem Ausdruck in meinen unterlagen nicht.WElche Struktur hat das ganze?
`delimiter` ist ein Schlüsselwortargument von den entsprechenden Methoden/Funktionen im `csv` Modul.

Verfasst: Samstag 28. Oktober 2006, 11:37
von Jerala
Hi Black Jack!

ja, so was einfaches suche ich, aber die Zahlen kenne ich ja nicht. Die sind quasi unsichtbar für mich in der Datei(ganz viele Zahlen in mehreren Zeilen und Spalten) und ich will die automatisch auslesen und das format umwandeln.

Hab in den älteren Einträgen des Forums, hier sowas gefunden: vielleicht kann ich das auf mein Problem zuschneiden:

Code: Alles auswählen

def commify(number, comma=",", thousand="."): 
    n = str(number).split(comma) 
    n[0] = list(str(n[0]))[::-1] 
    n[0] = thousand.join( 
            ["".join(n[0][i:i+3][::-1]) for i in      
             range(0,len(n[0]),3)][::-1]) 
    return comma.join(n) 

print commify(100000000) 
print commify(1000.58,comma=".",thousand=",") 
print commify("2,45") 
print commify(1234567) 
print commify("22343435455423423,2344324234")
Edit (Leonidas): Code in Python-Tags gesetzt.

Verfasst: Samstag 28. Oktober 2006, 11:42
von Leonidas

Verfasst: Samstag 28. Oktober 2006, 11:47
von Jerala
???
nichts - copy,paste

Verfasst: Samstag 28. Oktober 2006, 11:50
von Jerala
ach so, ok

Verfasst: Samstag 28. Oktober 2006, 11:51
von Leonidas
Jerala hat geschrieben:nichts - copy,paste
Eben nicht. Weil dann einer der Moderatoren erstmal vorbeikommen muss und deinen Post editieren muss.

Verfasst: Samstag 28. Oktober 2006, 12:01
von Jerala
Hab gedacht, so eine einfache Zeile müßte schon funktionieren, tut sie aber nicht, was ist falsch?

Code: Alles auswählen

file1='C:/XXX.txt'
file2='C:/XXX.xls'
Datei=open(file1,'r')
lines =Datei.readlines()
Datei.close()

def str_to_float(s): 
    commapos = s.rfind(".") 
    return float(s[:commapos].replace(".","") ) 

Datei=open(file2,'w')

for l in lines:
	Datei.write(l)

Datei.close()

Verfasst: Samstag 28. Oktober 2006, 12:47
von BlackJack
Jerala hat geschrieben:Hab gedacht, so eine einfache Zeile müßte schon funktionieren, tut sie aber nicht, was ist falsch?
Du kopierst nur eine Datei in eine andere. Anscheinend versuchst Du eine Exceltabelle zu erstellen, das geht so gar nicht. Exceltabellen sind nicht einfach nur Textdateien.

Kannst Du Deine Textdatei nicht unter Excel als CSV Datei einlesen? Die Daten liegen doch schon passend vor.

Code: Alles auswählen

def str_to_float(s): 
    commapos = s.rfind(".") 
    return float(s[:commapos].replace(".","") ) 
Ich dachte die Zahlen haben schon einen Dezimalpunkt im Original!? Und diese Funktion ist eine komplizierte Art um Nachkommastellen abzuschneiden. Der interaktive Interpretierer ist immer ganz nützlich wenn man sehen will was die einzelnen Komponenten so machen:

Code: Alles auswählen

In [25]: a = '42.23'

In [26]: b = a.rfind('.')

In [27]: a[:b]
Out[27]: '42'

In [28]: a[:b].replace('.', '')
Out[28]: '42'

In [29]: float(a[:b].replace('.', ''))
Out[29]: 42.0