在做测试的时候,经常需要把一些信息输出到控制台,但是格式上比较乱,想弄成一个类似SQL客户端的那个输出格式,在参考了一些资料后自己写了一个简单的控制台网格输出的类,分享代码供大家参考。
使用方法:暂时支持了map和list两种类型的数据展示,并没有提供header功能。
public static void main(String[] args) {
List ss0 = Arrays.asList("234", "432", "54");
List ss3 = Arrays.asList("234", "432", "54", "54", "54");
List ss1 = Arrays.asList("6546", "7675");
Map sss = new HashMap<>();
sss.put(getNanoMark() + EMPTY, "fdsf");
sss.put(getNanoMark() + EMPTY, "fdsfdsaff");
sss.put(getNanoMark() + EMPTY, "fdsf");
sss.put(getNanoMark() + EMPTY, "fdsfafdsf");
sss.put(getNanoMark() + EMPTY, "fdsf");
sss.put(getMark() + EMPTY, "fdsf");
show(sss);
List> rows = Arrays.asList(ss1, ss3, ss0);
show(rows);
JSONObject json = new JSONObject();
json.put("3234", 32432);
json.put("323dsa4", 32432);
json.put("3fdsa234", 32432);
json.put("323fdsf4", 32432);
json.put("32d34", 32432);
json.put("32fdsafdf34", 32432);
show(json);
}
效果展示:
类代码如下(下一步优化其他数据类型和header以及边栏支持):
package com.fun.utils;
import com.fun.frame.SourceCode;
import net.sf.json.JSONObject;
import org.apache.commons.lang3.StringUtils;
import java.util.*;
import java.util.stream.Collectors;
public class ConsoleTable extends SourceCode {
List rowLength = new ArrayList<>();
public static void show(Map map) {
new ConsoleTable(map);
}
public static void show(List> rows) {
new ConsoleTable(rows);
}
/**
* 输出map
*
* @param map
*/
private ConsoleTable(Map map) {
Set set = map.keySet();
int asInt0 = set.stream().mapToInt(key -> key.toString().length()).max().getAsInt();
rowLength.add(asInt0 + 2);
List values = new ArrayList<>();
set.forEach(key -> values.add(map.get(key).toString()));
int asInt1 = values.stream().mapToInt(value -> value.length()).max().getAsInt();
rowLength.add(asInt1 + 2);
StringBuffer stringBuffer = new StringBuffer(LINE + getHeader());
map.forEach((k, v) -> {
stringBuffer.append(getCel(0, k.toString()));
stringBuffer.append(getCel(1, v.toString()));
});
output(stringBuffer.append(LINE + getHeader()).toString());
}
/**
* 输出list
*
* @param rows
*/
private ConsoleTable(List> rows) {
for (int i = 0; i < rows.size(); i++) {
List line = rows.get(i);
for (int j = 0; j < line.size(); j++) {
String s = line.get(j);
if (rowLength.size() <= j) rowLength.add(0);
if (rowLength.get(j) < s.length()) rowLength.set(j, s.length());
}
}
rowLength = rowLength.stream().map(n -> n + 2).collect(Collectors.toList());
StringBuffer stringBuffer = new StringBuffer(LINE + getHeader());
for (int i = 0; i < rows.size(); i++) {
List line = rows.get(i);
for (int j = 0; j < rowLength.size(); j++) {
stringBuffer.append(getCel(j, j < line.size() ? line.get(j) : EMPTY));
}
}
output(stringBuffer.append(LINE + getHeader()).toString());
}
/**
* 获取每一格的string
*
* @param colum 列
* @param content 格内容
* @return
*/
public String getCel(int colum, String content) {
Integer integer = rowLength.get(colum);
int i = integer - content.length();
return (colum == 0 ? LINE + PART : PART) + getManyString(SPACE_1, i / 2) + content + getManyString(SPACE_1, i - i / 2) + (rowLength.size() - colum == 1 ? PART : EMPTY);
}
/**
* 获取头尾行
*
* @return
*/
private String getHeader() {
List collect = rowLength.stream().map(size -> getManyString("-", size)).collect(Collectors.toList());
return "+" + StringUtils.join(collect.toArray(), "+") + "+";
}
}
这里使用了一些stream的用法,虽然比较生疏,但是效果很不错,stream语法很强大,使得编码效率急速提升。在groovy语言使用java的stream各种方法时,还是遇到了不少的坑,目前主要还是符号兼容的问题比较多,所以尽量还是java stream的自己的语法比较好。
欢迎有兴趣的童鞋一起交流