使用環境
window 10Home
eclipse: 2022-03
orangesignal-csv-1.3.1
CSVを扱う練習のためにダウンロードしてファイルを読みこみセーブしようとしましたが
StringArrayListHandlerでは指定した項目のものを取り出してくれるのですが・・・
ColumnNameMapListHandlerではエラーが出て機能してくれません。
Exception in thread "main" java.lang.IllegalArgumentException: Invalid column position 4
at jp.sf.orangesignal.csv.filters.CsvExpressionUtils.validate(CsvExpressionUtils.java:267)
at jp.sf.orangesignal.csv.filters.CsvExpressionUtils.eq(CsvExpressionUtils.java:102)
at jp.sf.orangesignal.csv.filters.CsvExpressionUtils.in(CsvExpressionUtils.java:139)
at jp.sf.orangesignal.csv.filters.ColumnNameInExpression.accept(ColumnNameInExpression.java:83)
at jp.sf.orangesignal.csv.handlers.ColumnNameMapListHandler.load(ColumnNameMapListHandler.java:116)
at jp.sf.orangesignal.csv.handlers.AbstractCsvListHandler.load(AbstractCsvListHandler.java:75)
at jp.sf.orangesignal.csv.handlers.AbstractCsvListHandler.load(AbstractCsvListHandler.java:32)
at jp.sf.orangesignal.csv.Csv.load(Csv.java:69)
at jp.sf.orangesignal.csv.Csv.load(Csv.java:83)
at jp.sf.orangesignal.csv.Csv.load(Csv.java:98)
at jp.sf.orangesignal.csv.Csv.load(Csv.java:129)
at Main.main(Main.java:16)
と表示されて保存されません。どうしてでしょうか
使用予定のCVSファイル(コードではPrefature2 Set.csvとなっているもの)
・ファイルの内容
都道府県名,人口,高齢者率,都道府県,地方
北海道,5228885,29.00%,1,北海道
青森県,1238730,29.90%,2,東北
岩手県,1211206,30.20%,3,東北
宮城県,2303487,25.20%,4,東北
秋田県,960113,33.60%,5,東北
山形県,1068696,30.60%,6,東北
福島県,1834198,28.30%,7,関東
茨城県,2868554,26.50%,8,関東
栃木県,1934016,25.80%,9,関東
群馬県,1940333,27.40%,10,関東
埼玉県,7346836,24.60%,11,関東
千葉県,6287034,25.50%,12,関東
東京都,14064696,22.20%,13,関東
・
・
(以下略)
html
1import java.io.File; 2import java.io.IOException; 3import java.util.ArrayList; 4import java.util.List; 5import java.util.Map; 6import jp.sf.orangesignal.csv.Csv; 7import jp.sf.orangesignal.csv.CsvConfig; 8import jp.sf.orangesignal.csv.filters.CsvExpressions; 9import jp.sf.orangesignal.csv.handlers.ColumnNameMapListHandler; 10import jp.sf.orangesignal.csv.handlers.StringArrayListHandler; 11 12public class Main { 13 14 public static void main(String[] args) { 15 try { 16 List<Map<String,String>> data=Csv.load(new File("Prefature2 Set.csv"),"windows-31j", new CsvConfig(),new ColumnNameMapListHandler().filter(CsvExpressions.in("地方", "東北"))); 17 Csv.save(data, new File("example.csv"), new CsvConfig(), new ColumnNameMapListHandler()); 18 } catch (IOException e) { 19 // TODO 自動生成された catch ブロック 20 e.printStackTrace(); 21 } 22 23 } 24 25} 26 27 28
回答2件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。