一个.txt文件。使用下面的java代码读取文件并使用二维数组(用户的一维和产品的其他维度)来存储订单#。另外,使用字典将每个用户映射到其对应的数组行。如何用二维数组中的0替换缺失值?Java HashMap:如何修改矩阵的输出?
用户,产品,订单号:
name1 p1 5
name1 p2
name1 p3 2
name2 p1 3
name2 p2 1
name2 p3
name3 p1 5
name3 p2
name3 p3 2
name4 p1 3
name4 p2 1
name4 p3
下面的解决方案进行加工。但缺失值时,二维数组将具有不同的列长度。如何用0替换缺失值以生成固定在列上的矩阵?
output:
5 0 2
3 1 0
5 0 2
3 1 0
Map<String, LinkedHashMap<String, Integer>> orderInfo = new LinkedHashMap<>();
while (userScanner.hasNextLine()) {
String line = userScanner.nextLine();
// To-Do : check regx
String[] columns = line.split("\\t");
String userId = columns[0];
String productId = columns[1];
int order = Integer.parseInt(columns[2]);
LinkedHashMap<String, Integer> prodMap = orderInfo.get(userId);
if (prodMap == null || prodMap.isEmpty()) {
prodMap = new LinkedHashMap<String, Integer>();
}
prodMap.put(productId, new Integer(order));
orderInfo.put(userId, prodMap);
}
int[][] matrix = new int[orderInfo.size()][];
int row = 0 ;
// dictionary will contain Name as a key and belonging row as a value
Map<String,Integer> dictionary = new HashMap<String,Integer>();
for (Entry<String, LinkedHashMap<String, Integer>> entry : orderInfo.entrySet())
{
dictionary.put(entry.getKey(), row);
matrix[row] = new int[entry.getValue().size()];
int columns = 0;
for(Entry<String, Integer> ent : entry.getValue().entrySet())
{
matrix[row][columns] = ent.getValue();
columns = columns + 1;
}
row = row + 1;
}
for (int rw = 0; rw < matrix.length; rw++) {
for (int col = 0; col < matrix[rw].length; col++) {
System.out.print(matrix[rw][col]+" ");
}
System.out.println();
}
System.out.println(dictionary);
上面的代码只可以产生类似矩阵:
5 2
3 1
5 2
3 1
是否'INT为了=的Integer.parseInt(列[2]);'不扔你NumberFormatException的?如果没有,那么'订单'的价值是什么? – user3207158
如果我用0替换缺失的值,它不会抛出NumberFormatException。但是,.txt文件包含缺少的值。我的问题是如何从.txt文件读取数据时用0替换缺失值?谢谢! – Harry
我很困惑。你说如果用数字(0)替换缺失的列,它不会抛出异常。但是在OP中,你说代码已经工作(工作)了。那么你的编码是否与缺失的数字一起工作并产生你提供的5乘2矩阵? – user3207158