❤️ Helfen Sie noch heute, unser LibreOffice Forum zu erhalten! ❤️
Unterstützen Sie das LibreOffice-Forum und helfen Sie uns, unser Ziel für 2025 zu erreichen!

🍀 Jeder Beitrag zählt – vielen Dank für Ihre Unterstützung!🍀
Mit Ihrer Spende sichern Sie den Fortbestand, den Ausbau und die laufenden Kosten dieses Forums. 🌱


❤️ DANKE >> << DANKE ❤️

>> Dank Ihrer Unterstützung -> Keine Werbung für alle registrierten LibreOffice-Forum User! <<
🤗 Als Dankeschön werden Sie im Forum als LO-SUPPORTER gekennzeichnet. 🤗

Messdaten lichten

CALC ist die Tabellenkalkulation, die Sie immer wollten.
Antworten
Benutzeravatar
Ekkehardt
Beiträge: 4
Registriert: Fr 12. Dez 2014, 13:18

Messdaten lichten

Beitrag von Ekkehardt » Fr 12. Dez 2014, 13:27

Hallo,

ich habe eine Anzahl Tabellen mit Messwerten, welche numerisch abgeleitet werden sollen. Derzeit haben die Tabellen >30000 Zeilen und bei der Ableitung entsteht zu viel Rauschen. Deshalb möchte ich die Daten lichten, ohne die Aussage wesentlich zu verändern. Zum Beispiel in dem nur jeder 100. Wert (Zeile) behalten wird, der Rest gelöscht. Alternativ könnte auch die Festlegung einer zu behaltenden Anzahl Messwerte gegeben sein und die Spanne automatisch berechnet werden.

Gibt es bereits ein Makro, dass einen der beiden Wege umsetzt? Da ich von der Markoprogrammierung keine Ahnung habe, weiß ich nicht, wie so etwas umzusetzen wäre.

Benutzeravatar
lorbass
* LO-Experte *
Beiträge: 627
Registriert: Mo 25. Apr 2011, 18:17

Re: Messdaten lichten

Beitrag von lorbass » Fr 12. Dez 2014, 17:38

Ekkehardt hat geschrieben:Messwerten, welche numerisch abgeleitet werden sollen.
Mit „numerisch ableiten“ meinst du die Bildung eine Differentialquotienten? Wenn ja, verträgt sich das mit dem mehr oder weniger willkürlichen Streichen von 99% der Messdaten imho nur, wenn die Daten einem linearen Zusammenhang gehorchen, der Differentialquotienten also konstant ist.

Wenn dem so ist, brauchst du kein Makro, sondern verwendest die Calc-Funktion INDIREKT.

Code: Alles auswählen

=INDIREKT("A"&ZEILE()*<faktor>-<offset>)
Durch geeignete Wahl des Faktors, den du auch durch irgendeinen funktionalen Zusammenhang bestimmen kannst, kannst du Menge deine Messdaten eindampfen. Mit dem Ausdruck

Code: Alles auswählen

=INDIREKT("A"&ZEILE()*$B$1-($B$1-1))

und B1=100 extrahierst du den 1., 101., 201., … Messpunkt in die Zellen C1, C2, C3, … Mit einem zweiten Parameter neben der Schrittweite für den Startpunkt (statt der »1«) ergibt sich nach äquivalenter Umformung

Code: Alles auswählen

=INDIREKT("A"&<start>+(ZEILE()-1)*<schrittweite>)
Gruß
lorbass

Benutzeravatar
Ekkehardt
Beiträge: 4
Registriert: Fr 12. Dez 2014, 13:18

Re: Messdaten lichten

Beitrag von Ekkehardt » Di 16. Dez 2014, 12:34

Das funktioniert so leider nicht wie gewünscht. Ich erhalte nicht den Inhalt der 101., 201. usw. Zeile, sondern Werte aus Zeilen größer 350 mit kleinerer Schrittweite.

Wenn ich folgendes Shellskript auf die Daten anwende:

Code: Alles auswählen

#!/bin/bash
# schreibe die ersten 6 Zeilen der Datei data.txt in output.txt
head -n 6 data.txt > output.txt
# schreibe beginnend bei der Zeile 7 jede hundertste Zeile in die Datei, bis das Ende erreicht ist.
for i in $(seq 7 100 $(wc -l data.txt | cut -d " " -f 1)); do 
    sed ""$i"q;d" data.txt >> output.txt
done
dann erhalte ich aus einer Datei wie dieser http://paste.ubuntu.com/9539556/ das gewünschte Ergebnis in dieser Form: http://paste.ubuntu.com/9539557/.

Leider habe ich aber an der Universität nicht immer Linux zur Verfügung. Ich könnte nur versuchen, Cygwin zu bekommen, dann könnte ich auch da diesen Weg gehen.

Benutzeravatar
karolus
* LO-Experte *
Beiträge: 2580
Registriert: Fr 10. Dez 2010, 10:01

Re: Messdaten lichten

Beitrag von karolus » Di 16. Dez 2014, 13:23

Hallo

siehe Anhang
jede_hundert.ods
(191.08 KiB) 93-mal heruntergeladen

Code: Alles auswählen

with open('ekkehardt.txt') as input, open('ekkeout.txt', 'w') as output:
    for _ in range(6):
        output.write(next(input))
    for n, line in enumerate(input):
        if n%100 == 0:
            output.write(line)
 
Karolus
Zuletzt geändert von karolus am Di 16. Dez 2014, 13:58, insgesamt 2-mal geändert.
LO25.2.x.y debian 13(trixie) auf Raspberry5 8GB (64bit)
LO25.8.x.y flatpak debian 13(trixie) auf Raspberry5 8GB (64bit)

Benutzeravatar
Ekkehardt
Beiträge: 4
Registriert: Fr 12. Dez 2014, 13:18

Re: Messdaten lichten

Beitrag von Ekkehardt » Di 16. Dez 2014, 13:31

Danke, Karolus, das funktioniert. Mit der Funktion INDEX statt INDIREKT.

Benutzeravatar
lorbass
* LO-Experte *
Beiträge: 627
Registriert: Mo 25. Apr 2011, 18:17

Re: Messdaten lichten

Beitrag von lorbass » Di 16. Dez 2014, 20:37

Nur der Vollständigkeit halber: Mit INDIREKT funktioniert's auch. Meine allgemeine Formel oben muss nur an die Existenz von zwei Überschriftsszeilen angepasst werden.

Code: Alles auswählen

=INDIREKT("A"&3+(ZEILE(A1)-1)*100)
liefert dasselbe Ergebnis wie Karolus' Formeln in Spalte D.

Gruß
lorbass

Benutzeravatar
Ekkehardt
Beiträge: 4
Registriert: Fr 12. Dez 2014, 13:18

Re: Messdaten lichten

Beitrag von Ekkehardt » Mi 17. Dez 2014, 08:53

Vielen Dank :)


An alle, die das LibreOffice-Forum gern nutzen und unterstützen wollen:


Bitte helfen Sie uns mit 7 Euro pro Monat.
Durch Ihren Beitrag tragen Sie dazu bei, unsere laufenden Kosten für die kommenden Monate zu decken.
Unkompliziert per Kreditkarte oder PayPal.
Als ein kleines Dankeschön werden Sie im LO-Forum als SUPPORTER gekennzeichnet.



Antworten