java - 对从文件中读取的数组进行排序

标签 java sorting

第一次使用,如果我做错了什么,很抱歉。

我必须编写一个程序,根据用户输入的内容对数组进行排序。数据是从文件中读取的。文件 Bank.txt 包含 10,000 个帐户,其中一些是空帐户,默认值为 0000, ,00.00。

当前输出为:

ID#1234 joe     $436.0
ID#3620 kim     $600.0
ID#4563 Jimmy   $1653.0
ID#4571 Billy   $72.0
ID#5930 Brian   $962.0
ID#6766 Jen     $215.0
ID#7092 Adam    $8794.0

它看起来只是按ID排序,因为这是它在txt文档中的写入方式。我不知道从哪里开始。我需要根据用户输入的内容按 IDNameBalance 进行排序。我知道有 array.sort(array) ,但这在这里不起作用(除非我过度思考),因为它只会对当前的 id,name,balance 进行排序> 在该数组中。再次感谢任何帮助。

按名称排序应显示:

ID#7092 Adam    $8794.0
ID#4571 Billy   $72.0
ID#5930 Brian   $962.0
ID#6766 Jen     $215.0
ID#4563 Jimmy   $1653.0
ID#1234 joe     $436.0
ID#3620 kim     $600.0

按余额排序:

ID#4571 Billy   $72.0 <br>
ID#6766 Jen     $215.0 <br>
ID#1234 joe     $436.0 <br>
ID#3620 kim     $600.0 <br>
ID#5930 Brian   $962.0 <br>
ID#4563 Jimmy   $1653.0 <br>
ID#7092 Adam    $8794.0 <br>

程序代码:

import static java.nio.file.AccessMode.*;
import java.nio.file.*;
import java.io.*;
import java.util.Arrays;

public class ReadBankSequentially
{
    public static void main(String[] args)
    {
        Path file = Paths.get("Bank.txt");
        String[] array = new String[3];
        String s = "";
        String delimiter = ",";
        int id;
        String stringId;
        String name;
        double balance;

        try
        {

            InputStream input = new BufferedInputStream(Files.newInputStream(file));
            BufferedReader reader = new BufferedReader(new InputStreamReader(input));
            System.out.println();
            s = reader.readLine();
            while(s != null)
            {
                array = s.split(delimiter);
                stringId = array[0];
                id = Integer.parseInt(array[0]);
                if(id != 0)
                {
                    name = array[1];
                    balance = Double.parseDouble(array[2]);
                    System.out.println("ID#" + stringId + " " + name + " $" + balance); 

                }
                s = reader.readLine();
            }
            reader.close();
        }
        catch(Exception e)
        {
            System.out.println("Message: " + e);
        }
    }
}

最佳答案

我会创建一个客户 DTO:

public class Customer {
  protected int _id;
  protected String _name;
  protected float _balance;

  public Customer() {
    init(0, "New Customer", 0.00f);
  }

  public Customer(int id, String name, float balance) {
    init(id, name, balance);
  }

  private void init(int id, String name, float balance) {
    id(id).name(name).balance(balance);
  }

  public int id() {
    return this._id;
  }
  public Customer id(int id) {
    this._id = id;
    return this;
  }

  public String name() {
    return this._name;
  }
  public Customer name(String name) {
    this._name = name;
    return this;
  }

  public float balance() {
    return this._balance;
  }
  public Customer balance(float balance) {
    this._balance = balance;
    return this;
  }

  public String toString() {
    return String.format("#%d: %-5s - $%07.2f", id(), name(), balance());
  }
}

接下来我将创建一个实用程序类来读取文件并生成客户:

import java.io.File;
import java.io.FileNotFoundException;
import java.util.ArrayList;
import java.util.List;
import java.util.Scanner;

public class Utils {  
  public static List<Customer> getCustomers(String filename, String delimiters) {
    List<Customer> customers = new ArrayList<Customer>();
    Customer customer = null;
    File file = new File(filename);
    Scanner scanner = null;
    try {
      scanner = new Scanner(file);
      while (scanner.hasNextLine()) {
        String line = scanner.nextLine();
        if ((customer = createCustomer(line, delimiters)) != null)
          customers.add(customer);
      }
    } catch (FileNotFoundException e) {
      e.printStackTrace();
    } finally {
      scanner.close();
    }

    return customers;
  }

  public static Customer createCustomer(String line, String delimiter) {
    String[] arr = line.split(delimiter);
    if (arr.length < 3)
      return null;
    int id = Integer.parseInt(arr[0].trim());
    String name = arr[1].trim();
    float balance = Float.parseFloat(arr[2].trim());
    return new Customer(id, name, balance);
  }
}

最后,我将创建我的 Bank 类,它存储 Customer 并可以对它们进行排序/打印。

import java.util.Collections;
import java.util.Comparator;
import java.util.List;
import static bank.Utils.getCustomers;

public class Bank {
  protected List<Customer> customers;

  public enum Sort {
    ID, NAME, BALANCE
  }

  public Bank() {
    String filename = "bank/Bank.txt";
    String delimiters = "[,]";
    customers = getCustomers(filename, delimiters);

    printCustomers(Sort.ID, false);
    printCustomers(Sort.ID, true);
    printCustomers(Sort.NAME, false);
    printCustomers(Sort.NAME, true);
    printCustomers(Sort.BALANCE, false);
    printCustomers(Sort.BALANCE, true);
  }

  public void sortId(boolean descending) {
    final int d = descending ? -1 : 1;
    Comparator<Customer> comparator = new Comparator<Customer>() {
      public int compare(Customer c1, Customer c2) {
        return (c1.id() > c2.id() ? 1 :
               c1.id() == c2.id() ? 0 : -1) * d;
      }
    };
    Collections.sort(customers, comparator);
  }

  public void sortName(boolean descending) {
    final int d = descending ? -1 : 1;
    Comparator<Customer> comparator = new Comparator<Customer>() {
      public int compare(Customer c1, Customer c2) {
        return (c1.name().compareTo(c2.name())) * d;
      }
    };
    Collections.sort(customers, comparator);
  }

  public void sortBalance(boolean descending) {
    final int d = descending ? -1 : 1;
    Comparator<Customer> comparator = new Comparator<Customer>() {
      public int compare(Customer c1, Customer c2) {
        return (c1.balance() > c2.balance() ? 1 :
               c1.balance() == c2.balance() ? 0 : -1) * d;
      }
    };
    Collections.sort(customers, comparator);
  }

  public void printCustomers(Sort sortBy, boolean descending) {
    String header = "";
    String desc = descending ? "descending" : "ascending";
    switch (sortBy) {
      case NAME:
        header = "Sorting by Name";
        sortName(descending);
        break;
      case BALANCE:
        header = "Sorting by Balance";
        sortBalance(descending);
        break;
      case ID:
        header = "Sorting by Id";
      default:
        sortId(descending);
        break;
    }
    System.out.printf("### %s %s ###\n", header, desc);
    for (Customer c : customers)
      System.out.println(c);
    System.out.println();
  }

  public static void main(String[] args) {
    new Bank();
  }
}

输入文件

1234,Joe,436.00
3620,Kim,600.00
4563,Jimmy,1653.00
4571,Billy,72.00
5930,Brian,962.00
6766,Jen,215.00
7092,Adam,8794.00

输出

### Sorting by Id ascending ###
#1234: Joe   - $0436.00
#3620: Kim   - $0600.00
#4563: Jimmy - $1653.00
#4571: Billy - $0072.00
#5930: Brian - $0962.00
#6766: Jen   - $0215.00
#7092: Adam  - $8794.00

### Sorting by Id descending ###
#7092: Adam  - $8794.00
#6766: Jen   - $0215.00
#5930: Brian - $0962.00
#4571: Billy - $0072.00
#4563: Jimmy - $1653.00
#3620: Kim   - $0600.00
#1234: Joe   - $0436.00

### Sorting by Name ascending ###
#7092: Adam  - $8794.00
#4571: Billy - $0072.00
#5930: Brian - $0962.00
#6766: Jen   - $0215.00
#4563: Jimmy - $1653.00
#1234: Joe   - $0436.00
#3620: Kim   - $0600.00

### Sorting by Name descending ###
#3620: Kim   - $0600.00
#1234: Joe   - $0436.00
#4563: Jimmy - $1653.00
#6766: Jen   - $0215.00
#5930: Brian - $0962.00
#4571: Billy - $0072.00
#7092: Adam  - $8794.00

### Sorting by Balance ascending ###
#4571: Billy - $0072.00
#6766: Jen   - $0215.00
#1234: Joe   - $0436.00
#3620: Kim   - $0600.00
#5930: Brian - $0962.00
#4563: Jimmy - $1653.00
#7092: Adam  - $8794.00

### Sorting by Balance descending ###
#7092: Adam  - $8794.00
#4563: Jimmy - $1653.00
#5930: Brian - $0962.00
#3620: Kim   - $0600.00
#1234: Joe   - $0436.00
#6766: Jen   - $0215.00
#4571: Billy - $0072.00

关于java - 对从文件中读取的数组进行排序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16125694/

相关文章:

java - 用于重命名的 JAXB/XJC 外部绑定(bind)与多个 XSD 编译

java - 解码时对象方法出现问题?

java - 从 Java 列表结构中选择基数最低的元素

Python 列表排序取决于项目是否在另一个列表中

matlab - "Desort"一个矩阵。在 Matlab 中撤消排序

c++ - 为什么我的 AVL 树排序算法比插入排序算法花费的时间更长?

java - HostnameVerifier 与 TrustManager?

java - 如何在java中将透明alpha channel 添加回png图像?

php - 如何按字母顺序对目录内容进行排序,子目录出现在普通文件之前?

java - 使用 LostFocus 事件在 Java 中验证文本字段