NEWS
Zeiten filtern Array
-
-
@paul53 said in Zeiten filtern Array:
@diamand2k22 sagte: sortiertes Array, sortiert nach höchsten Preis
Das Array ist nach Uhrzeit sortiert.
@diamand2k22 sagte in Zeiten filtern Array:
den höchsten Preis in diesem Zeitraum ausgeben
const arr = [ [ 0.3781, '17:00', '17:30' ], [ 0.3781, '17:30', '18:00' ], [ 0.375, '18:00', '18:30' ], [ 0.375, '18:30', '19:00' ], [ 0.3569, '19:00', '19:30' ], [ 0.3569, '19:30', '20:00' ], [ 0.3488, '16:00', '16:30' ], [ 0.3488, '16:30', '17:00' ], [ 0.3422, '20:00', '20:30' ], [ 0.3422, '20:30', '21:00' ], [ 0.3369, '22:00', '22:30' ], [ 0.3369, '22:30', '23:00' ], [ 0.3349, '21:00', '21:30' ], [ 0.3349, '21:30', '22:00' ], [ 0.3343, '15:00', '15:30' ], [ 0.3343, '15:30', '16:00' ], [ 0.3242, '23:00', '23:30' ], [ 0.3242, '23:30', '00:00' ], [ 0.3113, '00:00', '00:30' ], [ 0.3113, '00:30', '01:00' ], [ 0.3078, '06:00', '06:30' ], [ 0.3078, '06:30', '07:00' ], [ 0.3064, '07:00', '07:30' ], [ 0.3064, '07:30', '08:00' ], [ 0.3029, '05:00', '05:30' ], [ 0.3029, '05:30', '06:00' ], [ 0.302, '08:00', '08:30' ], [ 0.3016, '01:00', '01:30' ], [ 0.3016, '01:30', '02:00' ], [ 0.2995, '02:00', '02:30' ], [ 0.2995, '02:30', '02:00' ], [ 0.2961, '03:00', '03:30' ], [ 0.2961, '03:30', '04:00' ], [ 0.2954, '04:00', '04:30' ], [ 0.2954, '04:30', '05:00' ], [ 0.2782, '14:00', '14:30' ], [ 0.2782, '14:30', '15:00' ], [ 0.2667, '10:00', '10:30' ], [ 0.2667, '10:30', '11:00' ], [ 0.2522, '11:00', '11:30' ], [ 0.2522, '11:30', '12:00' ], [ 0.2492, '12:00', '12:30' ], [ 0.2492, '12:30', '13:00' ], [ 0.2492, '13:00', '13:30' ], [ 0.2492, '13:30', '14:00' ] ]; let max = 0; for(const ele of arr) { if(ele[0] > max) max = ele[0]; }; log(max);
Hallo @paul53,
könntest du mit bitte noch sagen, wie ich aus dem Array mit der schleife den kleinsten Wert ausgebe?
Danke und Grüße! -
@diamand2k22 sagte: mit der schleife den kleinsten Wert ausgebe?
const arr = [ [ 0.3781, '17:00', '17:30' ], [ 0.3781, '17:30', '18:00' ], [ 0.375, '18:00', '18:30' ], [ 0.375, '18:30', '19:00' ], [ 0.3569, '19:00', '19:30' ], [ 0.3569, '19:30', '20:00' ], [ 0.3488, '16:00', '16:30' ], [ 0.3488, '16:30', '17:00' ], [ 0.3422, '20:00', '20:30' ], [ 0.3422, '20:30', '21:00' ], [ 0.3369, '22:00', '22:30' ], [ 0.3369, '22:30', '23:00' ], [ 0.3349, '21:00', '21:30' ], [ 0.3349, '21:30', '22:00' ], [ 0.3343, '15:00', '15:30' ], [ 0.3343, '15:30', '16:00' ], [ 0.3242, '23:00', '23:30' ], [ 0.3242, '23:30', '00:00' ], [ 0.3113, '00:00', '00:30' ], [ 0.3113, '00:30', '01:00' ], [ 0.3078, '06:00', '06:30' ], [ 0.3078, '06:30', '07:00' ], [ 0.3064, '07:00', '07:30' ], [ 0.3064, '07:30', '08:00' ], [ 0.3029, '05:00', '05:30' ], [ 0.3029, '05:30', '06:00' ], [ 0.302, '08:00', '08:30' ], [ 0.3016, '01:00', '01:30' ], [ 0.3016, '01:30', '02:00' ], [ 0.2995, '02:00', '02:30' ], [ 0.2995, '02:30', '02:00' ], [ 0.2961, '03:00', '03:30' ], [ 0.2961, '03:30', '04:00' ], [ 0.2954, '04:00', '04:30' ], [ 0.2954, '04:30', '05:00' ], [ 0.2782, '14:00', '14:30' ], [ 0.2782, '14:30', '15:00' ], [ 0.2667, '10:00', '10:30' ], [ 0.2667, '10:30', '11:00' ], [ 0.2522, '11:00', '11:30' ], [ 0.2522, '11:30', '12:00' ], [ 0.2492, '12:00', '12:30' ], [ 0.2492, '12:30', '13:00' ], [ 0.2492, '13:00', '13:30' ], [ 0.2492, '13:30', '14:00' ] ]; let max = 0; let min = 99; for(const ele of arr) { if(ele[0] > max) max = ele[0]; if(ele[0] < min) min = ele[0]; }; log(max); log(min);
-
perfekt! Funktioniert, wie immer vielen Danke für die schnelle Hilfe!!
-
@paul53 said in Zeiten filtern Array:
@diamand2k22 sagte: mit der schleife den kleinsten Wert ausgebe?
const arr = [ [ 0.3781, '17:00', '17:30' ], [ 0.3781, '17:30', '18:00' ], [ 0.375, '18:00', '18:30' ], [ 0.375, '18:30', '19:00' ], [ 0.3569, '19:00', '19:30' ], [ 0.3569, '19:30', '20:00' ], [ 0.3488, '16:00', '16:30' ], [ 0.3488, '16:30', '17:00' ], [ 0.3422, '20:00', '20:30' ], [ 0.3422, '20:30', '21:00' ], [ 0.3369, '22:00', '22:30' ], [ 0.3369, '22:30', '23:00' ], [ 0.3349, '21:00', '21:30' ], [ 0.3349, '21:30', '22:00' ], [ 0.3343, '15:00', '15:30' ], [ 0.3343, '15:30', '16:00' ], [ 0.3242, '23:00', '23:30' ], [ 0.3242, '23:30', '00:00' ], [ 0.3113, '00:00', '00:30' ], [ 0.3113, '00:30', '01:00' ], [ 0.3078, '06:00', '06:30' ], [ 0.3078, '06:30', '07:00' ], [ 0.3064, '07:00', '07:30' ], [ 0.3064, '07:30', '08:00' ], [ 0.3029, '05:00', '05:30' ], [ 0.3029, '05:30', '06:00' ], [ 0.302, '08:00', '08:30' ], [ 0.3016, '01:00', '01:30' ], [ 0.3016, '01:30', '02:00' ], [ 0.2995, '02:00', '02:30' ], [ 0.2995, '02:30', '02:00' ], [ 0.2961, '03:00', '03:30' ], [ 0.2961, '03:30', '04:00' ], [ 0.2954, '04:00', '04:30' ], [ 0.2954, '04:30', '05:00' ], [ 0.2782, '14:00', '14:30' ], [ 0.2782, '14:30', '15:00' ], [ 0.2667, '10:00', '10:30' ], [ 0.2667, '10:30', '11:00' ], [ 0.2522, '11:00', '11:30' ], [ 0.2522, '11:30', '12:00' ], [ 0.2492, '12:00', '12:30' ], [ 0.2492, '12:30', '13:00' ], [ 0.2492, '13:00', '13:30' ], [ 0.2492, '13:30', '14:00' ] ]; let max = 0; let min = 99; for(const ele of arr) { if(ele[0] > max) max = ele[0]; if(ele[0] < min) min = ele[0]; }; log(max); log(min);
Hallo @paul53,
noch ein Anliegen, könntest du mir bei der vorhandenen Konstellation sagen, wie ich aus dem Array den durchschnittlichen Wert ausgebe?
Danke nochmal für deine Hilfe und Grüße!
-
@diamand2k22 sagte: den durchschnittlichen Wert ausgebe?
let max = 0; let min = 99; let sum = 0; for(const ele of arr) { if(ele[0] > max) max = ele[0]; if(ele[0] < min) min = ele[0]; sum += ele[0]; }; log(max); log(min); log(sum / arr.length); // Durchschnitt
-
-
Hallo Paul,
hab folgendes Array, vorgefiltert mit z.B. Zeiten ab 0:00
[ [ 0.3839, '17:00', '17:30' ], [ 0.3839, '17:30', '18:00' ], [ 0.3766, '18:00', '18:30' ], [ 0.3766, '18:30', '19:00' ] ]
Die Variable sunup = 8:30 Uhr
async function filterZeit(arrZeit, sunup) { const newArray = []; for (let i = 0; i < arrZeit.length; i++) { const startTime = parseInt(arrZeit[i][1].split(':')[0]); newArray.push(arrZeit[i]); if (startTime == sunup.split(':')[0]) { break; } } newArray.sort(function (a, b) { return b[0] - a[0]; }); return newArray; }
jetzt soll das Skript die Zeiten zwischen 0:00 Uhr und 08:30 Uhr aus dem Array ausgeben.
Wenn jetzt Zeiten zwischen 0:00 Uhr und 8:30 Uhr im Array sind, werden die auch ausgegeben, aber wenn keine Zeiten zwischen 00:00 Uhr und 8:30 Uhr enthalten sind, wir aber trotzdem das Array mit Zeiten größer > 8:30 Uhr ausgebenwie bekomm ich es hin, dass dann ein leeres array [] ausgegeben wird?
-
@diamand2k22 sagte: leeres array [] ausgegeben wird?
Zeile 6:
if(startTime <= sunup.split(':')[0]) newArray.push(arrZeit[i]);
-
-
Hallo @paul53
hab wieder eine Frage.
ich habe das Array
[ [ 0.3839, '17:00', '17:30' ], [ 0.3839, '17:30', '18:00' ], [ 0.3766, '18:00', '18:30' ], [ 0.3766, '18:30', '19:00' ] ]
jetzt hab ich ein anderes Array mit Zeiten aber ohne Preise
[ [ '17:00', '17:30' ], [ '17:30', '18:00' ], [ '20:00', '20:30' ], [ '21:30', '22:00' ] ]
wie ist es möglich, die unteren Zeiten aus dem oberen Array rauszuschneiden?
Es kann auch vorkommen, dass z.B. Zeiten aus dem unteren Array in dem oberen nicht enthalten sind.Danke und Grüße
-
in c ist dann das gefilterte a-array
das sind mehr oder weniger 2 schleifen.
der filter befehl klappert alle elemente von a der reihe nach ab.
bei jedem durchgang wird dann die variable el gefüllt.
mit el wird dann das b-array durchsucht und die einzelnen inhalte verglichen.
auch beim suchen wird immer wieder jedes einzelne element in die variable sel gespeichert.
bei erfolg darf das element bleiben, bei misserfolg wird es ausgefiltertlet a=[ [ 0.3839, '17:00', '17:30' ], [ 0.3839, '17:30', '18:00' ], [ 0.3766, '18:00', '18:30' ], [ 0.3766, '18:30', '19:00' ] ]; let b=[ [ '17:00', '17:30' ], [ '17:30', '18:00' ], [ '20:00', '20:30' ], [ '21:30', '22:00' ] ]; let c= a.filter(ael=>b.find(bel=>ael[1]==bel[0]&&ael[2]==bel[1]));
hier mal nochmal eine übersichtlichere darstellung gegenüber der kompakten schreibweise
let c = a.filter( ael => b.find( bel => ael[1] == bel[0] && ael[2] == bel[1] ) );
https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/filter
https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/find -
-
mal schauen ob du den unterschied findest
let a=[ [ 0.3839, '17:00', '17:30' ], [ 0.3839, '17:30', '18:00' ], [ 0.3766, '18:00', '18:30' ], [ 0.3766, '18:30', '19:00' ] ]; let b=[ [ '17:00', '17:30' ], [ '17:30', '18:00' ], [ '20:00', '20:30' ], [ '21:30', '22:00' ] ]; let c= a.filter(ael=>!b.find(bel=>ael[1]==bel[0]&&ael[2]==bel[1]));
https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Operators/Logical_NOT
-
die Negierung
danke es funktioniert nun! -
Hallo ihr zwei, ich hab nochmal eine Frage zum Filtern von Zeiten.
Wie filter ich am einfachsten aus folgendem Array die kleinste Uhrzeit, also in dem Fall wäre es 2:00 Uhr, der Preis ist in dem Fall egal. Die Länge des Arrays kann beliebig variieren.
[ [ 0.2425, '03:00', '03:30' ], [ 0.2425, '03:30', '04:00' ], [ 0.2434, '02:00', '02:30' ], [ 0.2434, '02:30', '03:00' ], [ 0.2492, '04:00', '04:30' ] ]
Danke und Grüße
-
@diamand2k22 sagte in Zeiten filtern Array:
nur wenn mindestens ein element im array drin ist., ansonsten muss man das ergebnis vor ausgabe nochmal prüfen ob array auch mindestens ein element enthält
funktionsweise:
array wird sortiert anhand des 2 wertes jedes elements. damit daraus eine zahl wird, wird der : entfernt und in eine zahl umgewandelt.
am ende wird das erste element entnommen, was dann das kleinste istlet arr=[ [ 0.2425, '03:00', '03:30' ], [ 0.2425, '03:30', '04:00' ], [ 0.2434, '02:00', '02:30' ], [ 0.2434, '02:30', '03:00' ], [ 0.2492, '04:00', '04:30' ] ] console.log(arr.sort((a,b)=>parseInt(a[1].replace(":"))-parseInt(b[1].replace(":")))[0])
-
@diamand2k22 sagte: die kleinste Uhrzeit
Das funktioniert z.B. mit einem String-Vergleich.
const arr = [ [ 0.2425, '03:00', '03:30' ], [ 0.2425, '03:30', '04:00' ], [ 0.2434, '02:00', '02:30' ], [ 0.2434, '02:30', '03:00' ], [ 0.2492, '04:00', '04:30' ] ]; let first = '23:59'; for(const ele of arr) { if(ele[1] < first) first = ele[1]; }; log(first);
-
-
@diamand2k22 said in Zeiten filtern Array:
Hallo Paul,
hab folgendes Array, vorgefiltert mit z.B. Zeiten ab 0:00
[ [ 0.3839, '17:00', '17:30' ], [ 0.3839, '17:30', '18:00' ], [ 0.3766, '18:00', '18:30' ], [ 0.3766, '18:30', '19:00' ] ]
Die Variable sunup = 8:30 Uhr
async function filterZeitToSunup(arrZeit, sunup) { const newArray = []; // console.warn(JSON.stringify(arrZeit)); for (let i = 0; i < arrZeit.length; i++) { const startTime = parseInt(arrZeit[i][1].split(':')[0]); if(startTime <= sunup.split(':')[0]) newArray.push(arrZeit[i]); if (startTime == sunup.split(':')[0]) { // || startTime == 14 break; } } // console.warn(JSON.stringify(newArray)); newArray.sort(function (a, b) { // niedrieg preis sort return b[0] - a[0]; }); //console.warn(JSON.stringify(newArray)); return newArray; }
das Skript soll die Zeiten zwischen 0:00 Uhr und 08:30 Uhr aus dem Array ausgeben.
Wenn jetzt Zeiten zwischen 0:00 Uhr und 8:30 Uhr im Array sind, werden die auch ausgegeben, aber wenn keine Zeiten zwischen 00:00 Uhr und 8:30 Uhr enthalten sind, wir aber trotzdem das Array mit Zeiten größer > 8:30 Uhr ausgeben
wie bekomm ich es hin, dass dann ein leeres array [] ausgegeben wird?
hab jetzt noch eine Variable sundown, die gibt den Zeitpunkt des Sonnenuntergangs aus z.B 16:19 Uhr.
aktuell werden in der Funktion nur Zeiten von 0:00 Uhr bis sunup berücksichtigt. wie muss ich die Funktion anpassen, dass nur Zeiten zwischen sundown und sunup ausgegeben werden?