0

CCEの解決に問題があります。この割り当てでは、ユーザーが実行時に.txtファイルを開き、特定の正規表現(ACCやREJなど)が一致するかどうかを判断するために、コンパイラーにバックグラウンド解析を実行させる必要がありますが、問題はユーザーがJFileChooserでファイルを開く必要があります。私はこれを投稿する前に多くの読書と調査を行いましたが、問題は、私が理解しているようにjava.io.File自体を使用するJFileChooserが、このシナリオではScannerが.txtファイルの入力のみを解析できるように見えることです。

http://docs.oracle.com/javase/1.5.0/docs/api/java/io/class-use/File.html

したがって、スキャナーだけを使用してファイル内のすべてのテキスト行を読み取ると、「コンパイル」されましたが、表示されたすべてのコンソール出力は、たとえば、「null null null nullnull」でした(たとえば、5行のテキストがある場合ファイル)。便宜上、以下は許容できると見なされる.txtファイル(または略してACC)の例です。この例を編集すると、各ルールが別々の行に印刷されます。

S:AB A:0A A:e B:1B B:e

ソースコードを提供しました。charSequencesは、Scanner/BRが解析する必要のある実行可能な正規表現にすぎないことに注意してください。また、特定の行が拒否されている場合(REJ、省略形)、ユーザーに警告してすぐに終了する必要があります。どうやら私は思ったほどこれらのクラスを理解していないようです...多分私は何かを使用する必要がありますFileReaderのように、私は最初からベースから離れていますが、一般的なJavaIOの複雑さに非常に不満を感じています。私はこのすべての作業と努力を注ぎ込み、それを示すものがほとんどないので、それはとても落胆しています。

import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.File;
import java.io.FileNotFoundException; 
import java.io.FileReader;
import java.io.FileWriter;
import java.io.IOException;
import java.io.Reader;
import java.util.*;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
import javax.swing.JFileChooser;
import javax.swing.JOptionPane;

public class Simplified 
{


public Simplified() throws Exception
{   
    readLines();
}

public void readLines() throws Exception
{

    //MUST prompt user to use JFileChooser
    JFileChooser ranFi = new JFileChooser();
    //approve condition
    if(ranFi.showOpenDialog(null)==JFileChooser.APPROVE_OPTION)
    {
        //get selected file 
        Comparable<File> file = ranFi.getSelectedFile();
        //create a bufferedReader for the file 
        //BufferedReader br = new BufferedReader((Reader) file);
        BufferedReader br = null;

        //create local String object the refer to file's current line 
        String currentLine;

        /**************************
         * Length(LHS,RHS) = 1,1
         * --CharSequence compilations
         * ******************************
         */
        //ACC
        CharSequence fp100 = "[S][:][A-Ze0-1]";
        //ACC iff is NOT the very first line of text file 
        CharSequence fp101 = "[A-Z&&[^S]][:][A-Ze0-1]";


        /**************************
         * Length(LHS,RHS) = 1,2
         * --CharSequence compilations
         * ******************************
         */
        //ACC 
        CharSequence fp200 = "[S][:][A-Z0-1][A-Z0-1]";
        //ACC iff is NOT the very first line of text file 
        CharSequence fp201 = "[A-Z&&[^S]][:][A-Z0-1][A-Z0-1]";

        /**************************
         * Length(LHS,RHS) = 1,3 
         * --CharSequence compilations
         * ******************************
         */
        //ACC 
        CharSequence fp300 = "[S][:][A-Z0-1][A-Z0-1][A-Z0-1]";
        //ACC iff is NOT the very first line of text file 
        CharSequence fp301 = "[A-Z&&[^S]][:][A-Z0-1][A-Z0-1][A-Z0-1]";

        /**
         * Length(LHS,RHS) = 1,4 
         * --CharSequence compilations
         * ******************************
         */

        //REJ
        CharSequence fp400 = "[.][.][.][.][.][.]";


        //create a Scanner for the file 
        Scanner text = new Scanner((Readable) file);

        try
        {
            br = new BufferedReader((Reader) file);
            //while there are still lines to be read in the file 
            //where currentLine = present line of the bufferedReader
            while((currentLine = br.readLine()) != null)
            {

                //while the scanner still has lines to read in the file 
                while(text.hasNext())
                {


                //to remove trailing whitespace in the file, starting
                //@ the first line in the text file...
                String trimStartLine = currentLine.trim();

                //ALL feasible ACC permutations for starting line 
                if(trimStartLine.contains(fp100)||trimStartLine.contains(fp200)||trimStartLine.contains(fp300))
                {
                    System.out.println("first line valid...");


                }
                //ALL feasible REJ permutations for starting line
                else if(!trimStartLine.contains(fp100)||!trimStartLine.contains(fp200)||!trimStartLine.contains(fp300))
                {
                    System.out.println("invalid first line..." +
                            "...terminating");
                    System.exit(0);
                }

                //once again removing trailing whitespace in the file,
                //this time trimming the whitespace in the second line
                //of the file, provided that iff the first line of the
                //file was valid to begin with...
                String trim2ndLine = currentLine.trim();

                //permutations have now increased to 6 since "[S]" isn't
                //technically required for ANY line other than the first line 
                if(trim2ndLine.contains(fp100)||trim2ndLine.contains(fp101)||trim2ndLine.contains(fp200)||
                        trim2ndLine.contains(fp201)||trim2ndLine.contains(fp300)||trim2ndLine.contains(fp301))
                {
                    System.out.println("2nd line valid...");

                    //only included two line checks for now...
                    //as of now if the first two lines are valid
                    //then print out the remaining lines in the
                    //file...
                    System.out.println(text.nextLine());

                }
                else if(!trim2ndLine.contains(fp100)||!trim2ndLine.contains(fp101)||!trim2ndLine.contains(fp200)||
                        !trim2ndLine.contains(fp201)||!trim2ndLine.contains(fp300)||!trim2ndLine.contains(fp301))
                {
                    System.out.println("invalid 2nd line..." +
                            "...terminating");
                    System.exit(0);
                }
                else
                {
                    System.out.println("no file was selected");
                }

            }//end of inner while
            }//end of outer while 
        }//end of try
                catch (Exception ex)
                {
                    System.out.println(ex.getMessage());
                }   
                finally
                {   
                    try
                    {   //close text while lines remain,
                        //valid or not...
                        if(br != null && text != null){
                            br.close();
                            text.close();
                        }
                    }
                    catch (Exception ex)
                    {
                    }
                }//end of finally 
        System.out.println("end of file successfully reached...");
    }//end of approve option
}//end of method 




public static void main(String[] args) throws    Exception
{
    Simplified mn = new Simplified();
    mn.readLines();
}//end of main

}//end of Simplified.java 

結論として、ソースコード内の配置や、ScannerオブジェクトとBufferedReaderオブジェクトの型キャストに関係なく、常にCCEを取得しています。どんな助けでも途方もないでしょう。前もって感謝します。

4

1 に答える 1

1
  1. JFileChooser.getSelectedFileを返します、FileなぜあなたがそれをComparable<File>forで包もうとしているのか分かりませんか?ファイル自体はを実装しComparableます。
  2. Scanner入力としてを受け入れFileます。私はAPIの経験はありScannerませんが、が必要だとは思いません。ソースとしてを使用してをBufferedReader作成するだけで、実行するのに十分なはずです。ScannerFile

彼はあなたが試すことができる簡単なテストです。

  1. テストする必要のある内容を含む簡単なテキストファイルを自分で作成します。
  2. メソッドClassだけを持つシンプルを作成します。public static void main(String args[]) {...}

メソッドでは、次のmainようなものを試してください...

Scanner scanner = new Scanner(new File("path/to/text/file/text.txt"));
while (scanner.hasNext()) {
    System.out.println(scanner.next());
}

そこから、解析ロジックの追加を開始します。

于 2012-09-27T22:57:40.887 に答える