Java:将2D String数组打印为右对齐表

时间:2008-11-08 22:53:57

标签: java formatting printf

String[][]数组的单元格打印为右对齐表格的最佳方法是什么?例如,输入

{ { "x", "xxx" }, { "yyy", "y" }, { "zz", "zz" } }

应该产生输出

  x xxx
yyy   y
 zz  zz

这似乎是应该能够使用java.util.Formatter完成的事情,但它似乎不允许非常量字段宽度。最佳答案将使用一些标准方法来填充表格单元格,而不是手动插入空格字符。

3 个答案:

答案 0 :(得分:4)

实际上,如果为字段指定宽度,则应该右对齐 如果你需要一个动态填充,对于最长的字符串是最小的,你必须遍历数组,获得最大宽度,生成具有从这个最大值计算的宽度的格式字符串,并使用它来格式化输出。

答案 1 :(得分:4)

这是一个答案,为每列使用动态生成的格式字符串:

public static void printTable(String[][] table) {
  // Find out what the maximum number of columns is in any row
  int maxColumns = 0;
  for (int i = 0; i < table.length; i++) {
    maxColumns = Math.max(table[i].length, maxColumns);
  }

  // Find the maximum length of a string in each column
  int[] lengths = new int[maxColumns];
  for (int i = 0; i < table.length; i++) {
    for (int j = 0; j < table[i].length; j++) {
      lengths[j] = Math.max(table[i][j].length(), lengths[j]);
    }
  }

  // Generate a format string for each column
  String[] formats = new String[lengths.length];
  for (int i = 0; i < lengths.length; i++) {
   formats[i] = "%1$" + lengths[i] + "s" 
       + (i + 1 == lengths.length ? "\n" : " ");
 }

  // Print 'em out
  for (int i = 0; i < table.length; i++) {
    for (int j = 0; j < table[i].length; j++) {
      System.out.printf(formats[j], table[i][j]);
    }
  }
}

答案 2 :(得分:1)

找到最长字符串的长度。
左边用空格填充所有字符串直到它们长度为+ 1 System.out.print使用2个嵌套for循环