質問
CSVファイルをJavaのXLSまたはXLSXファイルに変換する迅速でクリーンな方法をここにいる人はいますか?
CSVファイルを既に管理するための何かがあり、他のプログラムに追加の互換性が必要です。
パッケージ名に加えてサンプルコードは常に高く評価されています。
どうもありがとう、
ジャスティアン
これがこれまでの私のコードです。回線から返品( " n")を削除する必要があります。私のセルの一部には複数の情報(リスト)が含まれているため、CSVで「 n」を使用して、 細胞, 、しかし、xlsはこれらを新しいものにすることを意味するかのようにこれらを扱います ライン.
コードはインターネットから変更されており、現時点では少し面倒です。 2004年に書かれたように、いくつかの非推奨方法に気付くかもしれません。また、ひどいリターンステートメントを無視してください。私は現時点でテストのためにSOPを使用しているだけで、後でそれをきれいにします。
package jab.jm.io;
import java.io.DataInputStream;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.util.ArrayList;
import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFRow;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
public class FileConverter {
public static String ConvertCSVToXLS(String file) throws IOException {
if (file.indexOf(".csv") < 0)
return "Error converting file: .csv file not given.";
String name = FileManager.getFileNameFromPath(file, false);
ArrayList<ArrayList<String>> arList = new ArrayList<ArrayList<String>>();
ArrayList<String> al = null;
String thisLine;
DataInputStream myInput = new DataInputStream(new FileInputStream(file));
while ((thisLine = myInput.readLine()) != null) {
al = new ArrayList<String>();
String strar[] = thisLine.split(",");
for (int j = 0; j < strar.length; j++) {
// My Attempt (BELOW)
String edit = strar[j].replace('\n', ' ');
al.add(edit);
}
arList.add(al);
System.out.println();
}
try {
HSSFWorkbook hwb = new HSSFWorkbook();
HSSFSheet sheet = hwb.createSheet("new sheet");
for (int k = 0; k < arList.size(); k++) {
ArrayList<String> ardata = (ArrayList<String>) arList.get(k);
HSSFRow row = sheet.createRow((short) 0 + k);
for (int p = 0; p < ardata.size(); p++) {
System.out.print(ardata.get(p));
HSSFCell cell = row.createCell((short) p);
cell.setCellValue(ardata.get(p).toString());
}
}
FileOutputStream fileOut = new FileOutputStream(
FileManager.getCleanPath() + "/converted files/" + name
+ ".xls");
hwb.write(fileOut);
fileOut.close();
System.out.println(name + ".xls has been generated");
} catch (Exception ex) {
}
return "";
}
}
解決
あなたがすでにこれを知っているかどうかはわかりませんが、:
- Excel(それがあなたの本当のターゲットの場合)は簡単に読むことができます
.csv
直接ファイルなので、あなたがする変換は、あなたの「才能のない」ユーザーにとってのみ礼儀になります。 - CSVは、最も低いコモンデノミネーター形式です。任意のコンバーターが、で見つかったものに情報を追加することはありそうにありません
.csv
より便利になるファイル。言い換えれば、CSVは「愚かな」形式であり、それを変換します.xls
おそらく)ファイルサイズを増やしますが、フォーマットをよりスマートにしません。
カーティスのポイの提案は、私の頭に浮かぶ最初のものです。
Windowsマシンでこのコンバージョンを行っている場合、別の選択肢がある可能性があります ジェイコブ, 、Javaプログラムから効果的にリモートコントロールが優れていることを可能にするJava-COMブリッジ。ファイルを開いて別の形式で保存し、おそらく何らかのフォーマットの変更などを適用することもできます。
最後に、SQLを実行することも成功しました INSERT
S(JDBC経由)JDBC-ODBCブリッジを介してアクセスされるExcelワークシートに。 IE ODBCは、Excelファイルをデータベースのように見せることができます。それはあまり柔軟ではありませんが、DBに任意の名前を作成するように頼むことはできません .XLS
ファイル。
編集:
それは私には見えます readLine()
すでにあなたに全線を与えていません。キャリッジリターンがラインターミネーターではないことをどのように知るのはどうですか? readline()の直後にデバッグ印刷ステートメントでこれを検証できるはずです。
これが確かにそうであるなら、それはあなたが
- 不完全な線を認識し、事実の後に一緒に貼り付けるかのどちらかです。
- または、readline()の代替物を作成します。簡単なアプローチは、文字ごとにキャラクターを読み、CSV文字列内のCRSを置き換え、完全なラインがあると感じるまで弦楽器にテキストを蓄積することです。
どちらの代替手段も、あなたがおそらく楽しみにしていなかった仕事です。
他のヒント
以下のプログラムをコピーして、プログラムを実行しましたが、正常に動作しています。このプログラムに懸念があるかどうかを教えてください。
import java.io.DataInputStream;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.util.ArrayList;
import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFRow;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.ss.usermodel.Cell;
public class CSVToExcelConverter {
public static void main(String args[]) throws IOException
{
ArrayList arList=null;
ArrayList al=null;
String fName = "test.csv";
String thisLine;
int count=0;
FileInputStream fis = new FileInputStream(fName);
DataInputStream myInput = new DataInputStream(fis);
int i=0;
arList = new ArrayList();
while ((thisLine = myInput.readLine()) != null)
{
al = new ArrayList();
String strar[] = thisLine.split(",");
for(int j=0;j<strar.length;j++)
{
al.add(strar[j]);
}
arList.add(al);
System.out.println();
i++;
}
try
{
HSSFWorkbook hwb = new HSSFWorkbook();
HSSFSheet sheet = hwb.createSheet("new sheet");
for(int k=0;k<arList.size();k++)
{
ArrayList ardata = (ArrayList)arList.get(k);
HSSFRow row = sheet.createRow((short) 0+k);
for(int p=0;p<ardata.size();p++)
{
HSSFCell cell = row.createCell((short) p);
String data = ardata.get(p).toString();
if(data.startsWith("=")){
cell.setCellType(Cell.CELL_TYPE_STRING);
data=data.replaceAll("\"", "");
data=data.replaceAll("=", "");
cell.setCellValue(data);
}else if(data.startsWith("\"")){
data=data.replaceAll("\"", "");
cell.setCellType(Cell.CELL_TYPE_STRING);
cell.setCellValue(data);
}else{
data=data.replaceAll("\"", "");
cell.setCellType(Cell.CELL_TYPE_NUMERIC);
cell.setCellValue(data);
}
//*/
// cell.setCellValue(ardata.get(p).toString());
}
System.out.println();
}
FileOutputStream fileOut = new FileOutputStream("test.xls");
hwb.write(fileOut);
fileOut.close();
System.out.println("Your excel file has been generated");
} catch ( Exception ex ) {
ex.printStackTrace();
} //main method ends
}
}
JavaでXLSまたはXLSXファイルを読み取りまたは書きたい場合、Apache Poiは良い賭けです。 http://poi.apache.org/
Excelのツールは、OPがやりたいことには適切ではありません。彼はそこで正しい軌道に乗っています。 Excelは、同じファイル内の複数のCSVファイルを異なるワークシートにインポートすることはできません。そのため、コードで実行したいのです。私の提案は、openCSVを使用してCSVを読み取ることです。これは、データや欠落している列のニューラインを自動的に修正できるため、無料でオープンソースです。実際には非常に堅牢で、あらゆる種類の異なる非標準CSVファイルを処理できます。
あなたが書いた:
CSVファイルを既に管理するための何かがあり、他のプログラムに追加の互換性が必要です。
他のプログラムは何ですか? Excelファイルを介してデータにアクセスする必要がありますか、それともJDBCまたはODBC接続をデータベースに操作できますか?データベースを中央の場所として使用すると、必要に応じてデータをCSVファイルまたはその他の形式に抽出できます。
私は呼ばれる小さなソフトウェアを作成しました csv2xls. 。 Javaが必要です。