0

私のテキストこれ

sirket;sehir;ilce;unvan;numara
AKSA SAT VE PAAMA ANM RKET KADY BES;STANBUL;KADIKY;A.S.;1230488;
KER BV SANAY;STANBUL;ZEYTNBURNU;A:S.;308133;
C.E.S.COSKUN MH.N.ELK.DAY.TK.MAL.VE GIDA TC.LTD.T.;HATAY;SKENDERUN;LTD. T.;14947;
ANLU GAZ TCARET VE SANY ANNM RKET KIRIKKALE UBES;KIRIKKALE;KIRIKKALE;A.S.;12519;
BVR GIDA MARİ NAAT TURZM SANAY VE TCARET LTD.T.;STANBUL;LO;LTD:STİ.;239;
ASA AKRLK KMYA SANAY (YALOVA UBES);YALOVA;FTLKKY;A.S.;551484;
WNCOR NXDORF LGSAYR SSTEER A.S.-ESNLER SUES;STANBUL;ESENLER;-;1027;
DESA DER SAN. VE TC.;STANBUL;BAKIRKY;A.S.;1480;
SNTM BLŞM TEKJLER SAN. VE TC;DYARBAKIR;YENEHR;A.S.;1439;

私は変化が欲しい "。" AS ,LTD.T.,LTD:STİ を含むunvan 列のみ、":" の代わりに文字を使用します。など.java がテキストを読むとき、最初の行を削除ます。どう書けばいいのだろう。

この出力が欲しい

KER BV SANAY;STANBUL;ZEYTNBURNU;A:S.;3083;
KER BV SANAY;STANBUL;ZEYTNBURNU;A.S.;308133;
BULVAR GIDA MAMLLERİ NAAT TURZM SANAY VE TCARET LTD.T.;STANBUL;LO;LTD:STİ.;2149;
BULVAR GIDA MAMLLERİ NAAT TURZM SANAY VE TCARET LTD.T.;STANBUL;LO;LTD.STİ.;239;

私のコードは

public class MaliyeBir {

    private static String inputPath = "C:\\deneme\\Maliye.csv";
    private static String outputPath = "C:\\yazdirilan\\YazdirilanMaliye.csv";
    private static BufferedReader bufferedReader;
    private static PrintWriter printWriter;

    public static void main(String[] args) {
       try {
           FileInputStream inputStream = new FileInputStream(inputPath);
           Reader reader = new InputStreamReader(inputStream, "ISO-8859-9");
           bufferedReader = new BufferedReader(reader);

           FileOutputStream outputStream = new FileOutputStream(outputPath);
           Writer writer = new OutputStreamWriter(outputStream, "ISO-8859-9");
           printWriter = new PrintWriter(writer);

           String line;

           while ((line = bufferedReader.readLine()) != null) {
               EndeksDegeri eD;
                eD = lineToClass(line);
                if (shouldOutput(eD)) {
                       printWriter.append(classToLine(eD, true));
                       printWriter.append(classToLine(eD, false));       
                   }               
           }

       } catch (IOException e) {
           e.printStackTrace();
       }
       finally {
           try {
               bufferedReader.close();
               printWriter.close();
           } catch (IOException e) {
               e.printStackTrace();
           }
       }

    }

    private static boolean shouldOutput(EndeksDegeri eD) {
       if (!eD.tip.contains(":")) {
           return false;
       }

       return true;
    }

    private static String classToLine(EndeksDegeri eD, boolean original) {
       if (!original) {
           eD.tip = eD.tip.replace(":", ".");
       }

       return eD.sirket.concat(";")
               .concat(eD.sehir).concat(";")
               .concat(eD.ilce).concat(";")
               .concat(eD.tip).concat(";")
               .concat(String.valueOf(eD.numara)
                .concat("\r\n")); 
    }

    private static EndeksDegeri lineToClass(String line) {
       String[] element = line.split(";");

       EndeksDegeri endeksDegeri = new EndeksDegeri();
       endeksDegeri.sirket = element[0];
       endeksDegeri.sehir = element[1];
       endeksDegeri.ilce = element[2];
       endeksDegeri.tip = element[3];
       endeksDegeri.numara = Integer.valueOf(element[4]);

       return endeksDegeri;
    }
4

2 に答える 2

1

これがコード内のファイル拡張子への参照から推測できる CSV ファイルである場合は、opencsvcsvなどの CSV 解析ライブラリを使用する方がはるかに優れています。 . その後、CSV ファイル オブジェクトを操作し、結果をファイルに保存できます。

于 2013-08-02T07:43:27.233 に答える
0

他の列に delimiter が含まれていないことが確実な場合は;、次のように Javasplit関数を使用してテキストを列に分割し、replace関数を使用してコロンをドットに置き換えることができます。

while ( (line = bufferedReader.readLine()) != null){
    String[] elements = line.split(";");
    if(elements[3].contains(":")){ // If the value in column "ulvan" contains ":"
        printWriter.append(line); // Print the original
        for(int i=0; i<elements.length; i++){
            if(i>0){
                printWriter.append(";"); // Print the delimiter
            }
            if(i==3){ // For column index 3, which is "ulvan"
                printWriter.append(elements[i].replace(":",".")); // Replace ':' with '.'
            } else { // For other columns, just print
                printWriter.append(elements[i]);
            }
        }
    }
}

簡単にするために、メイン関数にすべてを記述しました。必要に応じてモジュール化できます。

于 2013-08-02T07:49:43.000 に答える