Как мне выполнить 2-ю сортировку в flutter

#flutter #dart

#flutter #dart

Вопрос:

В dart mylist.sort((a,b) => a.mydate.compareTo(b.mydate)) будет отсортирован мой список по mydate в порядке возрастания.

Как мне также выполнить сортировку по a.quantity ?

В c # я бы использовал thenby сначала сортировку по дате, затем по количеству.

Комментарии:

1. сделайте это дважды? mylist.sort((a,b) => a.mydate.compareTo(b.mydate)); mylist.sort((a,b) => a.quantity.compareTo(b.количество));

2. если я сделаю это таким образом, это просто отсортирует его по количеству и обойдет mydate. мне это нужно по mydate, а затем по количеству. в c # вы бы использовали метод thenby.

3. @IqanShaikh Нет, Iterable.sort это не стабильная сортировка, так что это не сработает. Вам нужно будет использовать mergeSort from package:collection или что-то подобное.

Ответ №1:

Не смог найти ничего из коробки. Но обходной путь путем реализации compareTo метода в вашем классе

 class someclass {
  int quantity;
  DateTime mydate;
  
  someclass({this.quantity, this.mydate});
  
  int compareTo(someclass second) {
    int res = mydate.compareTo(second.mydate);
    if (res == 0) {
     return quantity.compareTo(second.quantity); 
    }
    return res;
  }
}
  

а потом x.sort((a,b) => a.compareTo(b));

https://gist.github.com/iqans/6cc01ceda5b318714a44e135a8876cb6

Ответ №2:

Вы можете скопировать вставить запустить полный код ниже,
вы можете implements Comparable и вызвать sort

фрагмент кода

 class Item implements Comparable<Item> {
  String name;
  DateTime mydate;
  int quantity;

  Item({this.name, this.mydate, this.quantity});

  @override
  int compareTo(Item other) {
    int dateDiff = mydate.compareTo(other.mydate);

    return dateDiff != 0 ? dateDiff : this.quantity.compareTo(other.quantity);
  }
}

List<Item> items = [
     ...
    ];

items.sort();

items.forEach((Item item) {
  print(
      '${item.name} - ${item.mydate.toIso8601String()} - ${item.quantity}');
});
  

вывод

 I/flutter (19496): c - 2020-01-01T00:00:00.000 - 4
I/flutter (19496): a - 2020-01-01T00:00:00.000 - 5
I/flutter (19496): d - 2020-02-01T00:00:00.000 - 3
I/flutter (19496): b - 2020-02-01T00:00:00.000 - 10
I/flutter (19496): e - 2020-03-01T00:00:00.000 - 3
  

полный код

 import 'package:flutter/material.dart';

class Item implements Comparable<Item> {
  String name;
  DateTime mydate;
  int quantity;

  Item({this.name, this.mydate, this.quantity});

  @override
  int compareTo(Item other) {
    int dateDiff = mydate.compareTo(other.mydate);

    return dateDiff != 0 ? dateDiff : this.quantity.compareTo(other.quantity);
  }
}

void main() {
  runApp(MyApp());
}

class MyApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      title: 'Flutter Demo',
      theme: ThemeData(
        primarySwatch: Colors.blue,
        visualDensity: VisualDensity.adaptivePlatformDensity,
      ),
      home: MyHomePage(title: 'Flutter Demo Home Page'),
    );
  }
}

class MyHomePage extends StatefulWidget {
  MyHomePage({Key key, this.title}) : super(key: key);

  final String title;

  @override
  _MyHomePageState createState() => _MyHomePageState();
}

class _MyHomePageState extends State<MyHomePage> {
  int _counter = 0;

  void _incrementCounter() {
    List<Item> items = [
      Item(
          name: "e",
          mydate: DateTime.parse("2020-03-01 00:00:00"),
          quantity: 3),
      Item(
          name: "a",
          mydate: DateTime.parse("2020-01-01 00:00:00"),
          quantity: 5),
      Item(
          name: "b",
          mydate: DateTime.parse("2020-02-01 00:00:00"),
          quantity: 10),
      Item(
          name: "c",
          mydate: DateTime.parse("2020-01-01 00:00:00"),
          quantity: 4),
      Item(
          name: "d",
          mydate: DateTime.parse("2020-02-01 00:00:00"),
          quantity: 3),
    ];

    items.sort();

    items.forEach((Item item) {
      print(
          '${item.name} - ${item.mydate.toIso8601String()} - ${item.quantity}');
    });

    setState(() {
      _counter  ;
    });
  }

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text(widget.title),
      ),
      body: Center(
        child: Column(
          mainAxisAlignment: MainAxisAlignment.center,
          children: <Widget>[
            Text(
              'You have pushed the button this many times:',
            ),
            Text(
              '$_counter',
              style: Theme.of(context).textTheme.headline4,
            ),
          ],
        ),
      ),
      floatingActionButton: FloatingActionButton(
        onPressed: _incrementCounter,
        tooltip: 'Increment',
        child: Icon(Icons.add),
      ),
    );
  }
}
  

Ответ №3:

Я использовал пакет Multi_Sort в pub.dev и отлично работал

Комментарии:

1. Пожалуйста, приведите пример кода, чтобы сделать этот ответ более понятным.