Jak posortować słownik z instancjami klasy?

Jak posortować słownik z instancjami klasy?
goku21
  • Rejestracja:ponad 7 lat
  • Ostatnio:6 miesięcy
  • Postów:91
0

Pisze w TypeScript.

Mam sobie instancje jakiejś klasy w dictionary, której instancje maja pole getRatio cos w stylu:

Kopiuj
export class Step{

    public _price:number = 5;
    private _depth20Asks:number;
    private _depth20Bids:number;

     constructor()
    {

    }

     public get depth20Asks():number
    {
        return this._depth20Asks;
    }

    public set depth20Asks(val:number)
    {
        this._depth20Asks = val;
    }

    public get depth20Bids():number
    {
        return this._depth20Bids;
    }

    public set depth20Bids(val:number)
    {
        this._depth20Bids = val;
    }

    public get bidsByAsksRatio():number
    {
        return this._depth20Bids/this._depth20Asks;
    }

Wczesniej ustalam sobie wszystkie liczby kiedy tworze instancje i wrzucam to do dictionary gdzieś w jakiejś innej klasie:

Kopiuj
export class foo {

private _possibleStepsDictionary:{[name:string]:Step} = {};

...
this._possibleStepsDictionary[name] = s;

}

I teraz chciałbym posortowacć nowy object po tej liczbie, ktora zwraca metoda public get bidsByAsksRatio():number wiec robie cos takiego:

Kopiuj
const sorted_object = Object.fromEntries(
    Object.entries(this._possibleStepsDictionary).sort(([,a],[,b]) => { b.bidsByAsksRatio - a.bidsByAsksRatio})
)

Nie sortuje :/ Nawet jak ustawie sobie pole _price jako public i zrobię:

Kopiuj
const sorted_object = Object.fromEntries(
    Object.entries(this._possibleStepsDictionary).sort(([,a],[,b]) => { b._price - a._price})
)

Dalej nie sortuje:/ Nie chce tego wrzucac do zwyklej tablicy bo zrobi mi się bajzel, chce mieć posortowane w key=>val dictionary ale cos nie idzie.

Jakies pomysly?

edytowany 3x, ostatnio: Riddle
KamilAdam
  • Rejestracja:ponad 6 lat
  • Ostatnio:28 dni
  • Lokalizacja:Silesia/Marki
  • Postów:5505
1
goku21 napisał(a):

Dalej nie sortuje:/ Nie chce tego wrzucac do zwyklej tablicy bo zrobi mi sie bajzel, chce miec posortowane w key=>val dictionary ale cos nie idzie. Jakies pomysly?

Mało rozumiem z tego kodu i mało znam TSa ale chyba się tam nie da bo domyślny słownik (Mapa?) w JSie (TSie) to hash słownik i nie zna pojecia porzadku wewnętrz siebie? Potrzebowałbyś tree słownika (jest coś takiego dla JSa/TSa w ogóle?)

UPDATE o prosze, jest coś takiego https://www.npmjs.com/package/ts-treemap


Mama called me disappointment, Papa called me fat
Każdego eksperta można zastąpić backendowcem który ma się douczyć po godzinach. Tak zostałem ekspertem AI, Neo4j i Nest.js . Przez mianowanie
edytowany 2x, ostatnio: KamilAdam
Paweł Łaski
Paweł Łaski
  • Rejestracja:ponad rok
  • Ostatnio:ponad rok
  • Postów:1
0
Xarviel
  • Rejestracja:ponad 3 lata
  • Ostatnio:około 2 godziny
  • Postów:847
3

Do posortowania obiektu wykorzystałbym Map, ponieważ zwykły obiekt nie musi gwarantować, że zachowa kolejność dodania właściwości i zależy to od środowiska (Node.js, silnik przeglądarki Chrome, silnik przeglądarki Firefoxa itd).

Bazując na takim przykładzie

Kopiuj
class Example {
  constructor(public value: number) {
    this.value = value;
  }
}

const dictionary = {
  bar: new Example(10), // { value: 10 }
  foo: new Example(5), // { value: 5 } 
};

Skorzystanie z Object.entries stworzy nam taką tablicę

Kopiuj
[
  ['bar', { value: 10 }],
  ['foo', { value: 5 }],
];

i żeby posortować to rosnąco wykorzystujemy obiekt Map, oraz metodę sort

Kopiuj
const sortedDictionary = new Map(Object.entries(dictionary).sort((itemA, itemB) => {
  return itemA[1].value - itemB[1].value;
}));
edytowany 4x, ostatnio: Xarviel
FG
  • Rejestracja:około 5 lat
  • Ostatnio:około 2 miesiące
  • Postów:57
0

Jaki jest sens sortowania struktury klucz - > wartość?

KamilAdam
  • Rejestracja:ponad 6 lat
  • Ostatnio:28 dni
  • Lokalizacja:Silesia/Marki
  • Postów:5505
1
FrontendGuy napisał(a):

Jaki jest sens sortowania struktury klucz - > wartość?

Np gdy iterujesz po strukturze klucz wartość (zwanej w np w Javie Map) to dostajesz pary w porostowanej kolejności. W Javie jest na to navet osobny interfejs SortedMap


Mama called me disappointment, Papa called me fat
Każdego eksperta można zastąpić backendowcem który ma się douczyć po godzinach. Tak zostałem ekspertem AI, Neo4j i Nest.js . Przez mianowanie
SL
  • Rejestracja:około 7 lat
  • Ostatnio:około 8 godzin
  • Postów:896
1
FrontendGuy napisał(a):

Jaki jest sens sortowania struktury klucz - > wartość?

Chcesz, żeby output był deterministyczny np. do testów, albo jak chcesz zrobić diffa. Zazwyczaj prościej jest doprowadzic output do deterministycznej formy niż napisać asercję, która jest czytelna, prosta i olewa kolejność

KamilAdam
Co było widać w Javie jak zmienili implementację HashMapy i wielu ludziom wiele testów się posypało. Bo chociaż HashMapa nie gwarantowała kolejności to ta losowa kolejnośc nie zmieniała się przez lata i była używana w testach XD
SL
Klasyk, google ma ciekawe podejście w tej sprawie, bo dodają kod, który sprawia, że kod zachowuje się za każdym razem inaczej. Przykładowo hash mapa w go ma niederministyczną kolejność na podstawie hasha, który jest generowany na start apki. Albo libka do zamiany protobufa na jsona, która czasami z d**y dodaje niepotrzebne spacje, żeby ukarać za porównywanie stringów ,

Zarejestruj się i dołącz do największej społeczności programistów w Polsce.

Otrzymaj wsparcie, dziel się wiedzą i rozwijaj swoje umiejętności z najlepszymi.