gpt4 book ai didi

java - 将文本文件分成 block

转载 作者:行者123 更新时间:2023-11-30 11:02:41 26 4
gpt4 key购买 nike

我正在尝试读取文本文件并将其分成 block 。下面是输入文本文件的模式:

DEFINE JOBSET ID=jobset_def FAILCOND=(1,9999)

DEFINE JOB ID=(jobset_def,job1_def,0010)
DESCRIPTION='Checks the data file against the token file'
DEFINE JOBPARM ID=(jobset_def,job1_def,0010) SUBFILE=/scripts/chk_file.ksh SUBUSER=pbods SUBPASS=*PASSWORD*
PARM1='parm1'
PARM2='parm2.dat'

DEFINE JOB ID=(jobset_def,job2_def,0030)
DEFINE JOBPARM ID=(jobset_def,job2_def,0030)
SUBFILE='exec_sess_instance.ksh' SUBUSER=pbods SUBPASS=*PASSWORD*
PARM1='parm1'
PARM2='parm2'
.......

我想将文本文件分成更小的 block ,然后将其存储到 HashMap 中。 HashMap 的每个值都是一个作业定义,即从DEFINE JOB ID 到下一个DEFINE JOB ID。下面是我的代码:

public class UpdateJobs {
public static void main(String[] args) throws IOException {
File file = new File("H:/Project_Documents/ALM/ns_pbds_gwm_uscore_account_omx.txt");
FileReader fileReader = new FileReader(file);
HashMap <Integer, StringBuffer> jobdef= new HashMap <Integer, StringBuffer>();
int i=1;
BufferedReader bufferedReader = new BufferedReader(fileReader);
StringBuffer stringBuffer = new StringBuffer();
Iterator<Integer> keySetIterator = jobdef.keySet().iterator();
String line;
while ((line = bufferedReader.readLine()) != null) {
if (line.contains("DEFINE JOB ID")){
jobdef.put(i, stringBuffer);
i++;
stringBuffer.setLength(0);
}
stringBuffer.append(line);
//System.out.println("Line is" +line);
stringBuffer.append("\n");
}
fileReader.close();
while(keySetIterator.hasNext()){
Integer key = keySetIterator.next();
System.out.println("key: " + key + " value: " + jobdef.get(key));
}
}
}

我遇到的问题是我没有得到任何输出。代码运行没有任何错误,但问题是每次它进入第一个 while 循环时,它都会在 hashmap 中创建一个条目,并在下一个条目上覆盖前一个条目并创建一个新条目,即

Loop1: 
key, value
1, DEFINE JOBSET ID=jobset_def FAILCOND=(1,9999)

DEFINE JOB ID=(jobset_def,job1_def,0010)
DESCRIPTION='Checks the data file against the token file'
DEFINE JOBPARM ID=(jobset_def,job1_def,0010) SUBFILE=/scripts/chk_file.ksh SUBUSER=pbods SUBPASS=*PASSWORD*
PARM1='parm1'
PARM2='parm2.dat'

Loop2:
key, value
1,DEFINE JOB ID=(jobset_def,job2_def,0030)
DEFINE JOBPARM ID=(jobset_def,job2_def,0030)
SUBFILE='exec_sess_instance.ksh' SUBUSER=pbods SUBPASS=*PASSWORD*
PARM1='parm1'
PARM2='parm2'

2,DEFINE JOB ID=(jobset_def,job2_def,0030)
DEFINE JOBPARM ID=(jobset_def,job2_def,0030)
SUBFILE='exec_sess_instance.ksh' SUBUSER=pbods SUBPASS=*PASSWORD*
PARM1='parm1'
PARM2='parm2'
....

在循环结束时,它在第二个 while 循环中不打印任何内容,即它删除 HashMap 中的所有条目。

我无法调试它,并且在过去 2 天一直停留在这个问题上。我们将不胜感激。

如果您需要更多说明,请告诉我。

谢谢

最佳答案

我认为这是因为你将StringBuffer对象本身作为一个值放入了HashMap中,并且由于它是一个Object,代码点随时随地访问内存中的同一区域。这意味着当您将 stringBuffer 放入 HashMap 并随后更改其内容时,HashMap 中的内容也会更改。

一个快速修复方法是在每次您在行中读取“DEFINE JOB ID”时实例化一个 new StringBuffer() 对象。

这意味着改变这个:

    StringBuffer stringBuffer = new StringBuffer();
Iterator<Integer> keySetIterator = jobdef.keySet().iterator();
String line;
while ((line = bufferedReader.readLine()) != null) {
if (line.contains("DEFINE JOB ID")){
jobdef.put(i, stringBuffer);
i++;
stringBuffer.setLength(0);
}
stringBuffer.append(line);
//System.out.println("Line is" +line);
stringBuffer.append("\n");
}

对此:

    StringBuffer stringBuffer = new StringBuffer();
Iterator<Integer> keySetIterator = jobdef.keySet().iterator();
String line;
while ((line = bufferedReader.readLine()) != null) {
if (line.contains("DEFINE JOB ID")){
stringBuffer = new StringBuffer();
jobdef.put(i, stringBuffer);
i++;
stringBuffer.setLength(0);
}
stringBuffer.append(line);
//System.out.println("Line is" +line);
stringBuffer.append("\n");
}

希望这对您有所帮助。

关于java - 将文本文件分成 block ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30689967/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com