我有一个 JSF 1.2 视图,它是一种报告生成器。用户可以选择一个查询,配置一些值,然后请求数据库并收集数据。之后可以在数据表中查看数据,最后导出到 Excel。到目前为止工作正常。
根据查询,列具有不同的类型,其中一种是 Double。Double 值现在应该四舍五入...
由于有很多行(数万或数十万),我将所有数据收集为字符串以避免耗时的类型转换。这很好,因为要导出到 Excel,我也需要字符串(写入 Office XML)。
但是现在四舍五入了。在数据表中,双打应该四舍五入。如果我有一个 Double,我可以轻松地使用 f:convertNumber,但我没有。
我的想法是一个字符串转换器,它分析它是否是一个数值,然后格式化字符串。(性能并不那么关键,因为分页数据表中只有 30 条左右的记录)。我将如何做到这一点?
任何(其他)建议?谢谢!
标记
编辑:
现在解决了
public class ReportStringConverter implements Converter {
DecimalFormat f = new DecimalFormat("#0.00");
public Object getAsObject(FacesContext context, UIComponent component, String value) {
return value;
}
public String getAsString(FacesContext context, UIComponent component, Object value) {
if (isNumeric(value.toString())) {
return f.format(Double.parseDouble(value.toString()));
} else {
return value.toString();
}
}
private boolean isNumeric(String s) {
try {
double d = Double.parseDouble(s);
} catch (NumberFormatException e) {
return false;
}
return true;
}
}