14

Javaでcsvファイルをxlsまたはxlsxファイルに変換する迅速でクリーンな方法を知っている人はいますか?

既に csv ファイルを管理するものがあり、他のプログラムとの追加の互換性が必要です。

パッケージ名に加えてサンプルコードは常に高く評価されています。

どうもありがとう、

ユスティアン

これまでの私のコードは次のとおりです。行からリターン ("\n") を削除する必要があります。一部のセルには複数行の情報 (リスト) が含まれているため、csv で "\n" を使用してセル内の複数行を示すことができますが、xls はこれらを新しいに配置するつもりであるかのように扱います。

コードはインターネットから変更されており、現時点では少し面倒です。2004 年に書かれたため、いくつかの非推奨のメソッドに気付くかもしれませんが、ひどい return ステートメントは無視してください。現時点ではテストのために 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 "";
    }
}
4

6 に答える 6

9

これをすでに知っているかどうかはわかりませんが、次のとおりです。

  • Excel (それが実際のターゲットである場合) は、ファイルを直接読み取ることが簡単にできる.csvため、行う変換は、あまり「才能のない」ユーザーへの礼儀にすぎません。
  • CSV は最小公倍数の形式です。コンバーターが、.csvファイル内にある情報をより便利にする情報を追加することはまずありません。つまり、CSV は「ダム」形式であり、変換する.xlsと (おそらく) ファイル サイズが大きくなりますが、形式がよりスマートになるわけではありません。

Curtis の POI の提案は、私も最初に頭に浮かぶものです。

この変換を Windows マシンで行っている場合、別の代替手段はJacobである可能性があります。これは、Java プログラムから Excel を効果的にリモート コントロールして、ファイルを開いて別の場所に保存するなどの操作を可能にする Java-COM ブリッジです。おそらく、いくつかの書式設定の変更などを適用することさえあります。

INSERT最後に、JDBC-ODBC ブリッジ経由でアクセスする Excel ワークシートに (JDBC 経由で) SQL を実行することにも成功しました。つまり、ODBC は Excel ファイルをデータベースのように見せることができます。ただし、あまり柔軟ではありません。DB に任意の名前の.XLSファイルを作成するように依頼することはできません。


編集:

readLine()私には、すでにあなたに全行を与えていないように見えます。キャリッジ リターンが行末記号ではないことをどのように知ることができますか? これは、readLine() の直後に debug print ステートメントで確認できるはずです。

これが本当にそうなら、それは最悪です。

  • 不完全な行を認識し、事後にそれらを貼り付けるか、
  • または、readLine() の独自の代替を作成します。簡単な方法は、1 文字ずつ読み取り、CSV 文字列内の CR を置き換え、行が完成したと感じるまで StringBuilder にテキストを蓄積することです。

どちらの選択肢も、おそらくあなたが楽しみにしていたものではありません。

于 2010-07-06T19:14:21.260 に答える
7

以下のプログラムをコピーして貼り付けます。プログラムを実行しましたが、正常に動作しています。このプログラムについて何か懸念がある場合はお知らせください。(このプログラムを実行するには Apache POI Jar が必要です)

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
    }
}
于 2014-07-22T13:57:04.977 に答える
7

Java で XLS または XLSX ファイルを読み書きしたい場合は、Apache POI が最適です: http://poi.apache.org/

于 2010-07-06T18:57:51.207 に答える
0

csv2xlsという小さなソフトウェアを作成しました。Java が必要です。

于 2014-07-11T07:27:57.993 に答える
0

あなたが書いた:

既に csv ファイルを管理するものがあり、他のプログラムとの追加の互換性が必要です。

それらの他のプログラムは何ですか?Excel ファイルを介してデータにアクセスする必要がありますか、それともデータベースへの JDBC または ODBC 接続を使用できますか? データベースを中央の場所として使用すると、必要に応じてデータを CSV ファイルまたはその他の形式に抽出できます。

于 2010-07-06T19:26:32.827 に答える