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!
textformat
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.
Such mal hier im Forum danach.
Das Trennzeichen kann über den Parameter delimiter = ";" eingestellt werden.
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
-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
http://www.cs.unm.edu/~dlchao/flake/doom/
So eine Zeile kannst Du, wenn sie als Zeichenkette vorliegt, mit der `split()` Methode zerlegen: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-
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']
`delimiter` ist ein Schlüsselwortargument von den entsprechenden Methoden/Funktionen im `csv` Modul.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?
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:
Edit (Leonidas): Code in Python-Tags gesetzt.
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")
-
- Python-Forum Veteran
- Beiträge: 16025
- Registriert: Freitag 20. Juni 2003, 16:30
- Kontaktdaten:
Eben nicht. Weil dann einer der Moderatoren erstmal vorbeikommen muss und deinen Post editieren muss.Jerala hat geschrieben:nichts - copy,paste
My god, it's full of CARs! | Leonidasvoice vs (former) Modvoice
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()
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.Jerala hat geschrieben:Hab gedacht, so eine einfache Zeile müßte schon funktionieren, tut sie aber nicht, was ist falsch?
Kannst Du Deine Textdatei nicht unter Excel als CSV Datei einlesen? Die Daten liegen doch schon passend vor.
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
def str_to_float(s): commapos = s.rfind(".") return float(s[:commapos].replace(".","") )
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