I am a beginner to Java. I have successfully exported user data input to a .txt file using a loop, but I would like to remove the last comma per every line of the file. I have tried using a delimiter but cannot get the replaceAll to successfully remove the last comma of every line.
My current method which exports data is this:
public void Quit()
{
System.out.println(ProjectList.get(0).ProjectName);
File fileObject = new File("results.txt");
CorrectInput = true;
ShowMenu = false; //if ShowMenu is false, the program's menu will terminate
PrintWriter outputStream = null;
try
{
outputStream =
new PrintWriter(new FileOutputStream("results.txt"));
}
catch(FileNotFoundException e)
{
System.out.println("Error opening the file" +"results.txt");
System.exit(0);
}
for (int i=0; i<ProjectList.size(); i++){
outputStream.print(ProjectList.get(i).ProjectName+","+ ProjectList.get(i).NumberOfMember +","); //Project Name and Number of Members exported
for (int Membercount = 0; Membercount < ProjectList.get(i).NumberOfMember; Membercount ++) //For as long as the member count is less than the total number of members, the program will ask for the user input
{
outputStream.print(ProjectList.get(i).TeamMember[Membercount]);
outputStream.print(",");
//END OF LIST OF MEMBERS
}
for (int CountingIndex = 0; CountingIndex < ProjectList.get(i).NumberOfMember; CountingIndex ++) //For as long as the member count is less than the total number of members, the program will ask for the user input
{
outputStream.print(ProjectList.get(i).TeamMember[CountingIndex] + ",");
for (int CountedIndex = 0; CountedIndex < ProjectList.get(i).NumberOfMember; CountedIndex++) {
if(CountingIndex!=CountedIndex) { //new, adding csv format
outputStream.print(ProjectList.get(i).TeamMember[CountedIndex] + ",");
outputStream.print(ProjectList.get(i).Vote[CountingIndex][CountedIndex] + ",");
}
}
}
//for (int CountedIndex = 0; CountedIndex < ProjectList.get(i).NumberOfMember && CountingIndex != CountedIndex; CountedIndex++)
outputStream.println();
}
outputStream.close();
// read file data into a String
// read file data into a String
String data = null;
try {
data = new Scanner(new File("results.txt")).useDelimiter("\\Z").next();
data = data.replaceAll("(?m)\\,$", " ");
} catch (FileNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
System.out.println("\tGoodbye. ");
scan.close();
}
An example .txt output looks like this:
PRO1,2,MEM1,MEM2,MEM1,MEM2,100,MEM2,MEM1,100,
PRO2,2,MEM3,MEM4,MEM3,MEM4,100,MEM4,MEM3,100,
But I would like the .txt/csv output to look like:
PRO1,2,MEM1,MEM2,MEM1,MEM2,100,MEM2,MEM1,100
PRO2,2,MEM3,MEM4,MEM3,MEM4,100,MEM4,MEM3,100
Should I move the try/catch statement for the scanner to a separate method? Thanks so much for your help.