我正在尝试使用解析 CSV 文件,jackson-dataformat-csv并且我想将数字列映射到 Number java 类型。
CsvSchema schema = CsvSchema.builder().setUseHeader(true)
.addColumn("firstName", CsvSchema.ColumnType.STRING)
.addColumn("lastName", CsvSchema.ColumnType.STRING)
.addColumn("age", CsvSchema.ColumnType.NUMBER)
.build();
CsvMapper csvMapper = new CsvMapper();
MappingIterator<Map<String, Object>> mappingIterator = csvMapper
.readerFor(Map.class)
.with(schema)
.readValues(is);
while (mappingIterator.hasNext()) {
Map<String, Object> entryMap = mappingIterator.next();
Number age = (Number) entryMap.get("age");
}
Run Code Online (Sandbox Code Playgroud)
我期待entryMap.get("age")应该是 a Number,但我得到了String。
我的 CSV 文件:
firstName,lastName,age
John,Doe,21
Error,Name,-10
Run Code Online (Sandbox Code Playgroud)
我知道这CsvSchema适用于 POJO,但我需要处理任意 CSV 模式,因此我无法为每种情况创建一个新的 java 类。
有什么方法可以将 CSV 解析为类型Map或Array?
我正在尝试配置我的JS构建以执行下一步:
我正在使用JS变量来定义应用程序根目录:
globals.js
define(function (require) {
"use strict";
return {
mainRoot: "http://myapp.com"
//mainRoot: "http://localhost:3000" - local run
//mainRoot: "http://myapp-test.com" - test server
};
});
Run Code Online (Sandbox Code Playgroud)
在本地开发期间,我使用的代码没有Grunt构建,只在测试和生产版本中运行Grunt.
Grunt使用命令行配置从Maven插件运行.所以它是传递环境变量的唯一方法.
的pom.xml
<plugin>
<groupId>pl.allegro</groupId>
<artifactId>grunt-maven-plugin</artifactId>
<configuration>
<gruntOptions>
<gruntOption>--verbose</gruntOption>
</gruntOptions>
<target>build</target>
</configuration>
</plugin>
Run Code Online (Sandbox Code Playgroud)
Grunt配置非常简单,看起来像这样:
Gruntfile.js
grunt.registerTask('build', [
'karma',
'requirejs',
'concat',
'csso',
'copy',
'processhtml'
]);
Run Code Online (Sandbox Code Playgroud)
问题:
如何配置Grunt以下一种方式更改我的变量?
mainRoot应该是http://localhost:3000PROD环境中运行Grunt时- mainRoot应该更改为 http://myapp.comTEST环境中运行Grunt时- mainRoot应该更改为 http://myapp-test.com谢谢!