JAVA
FileOutputStream 파일쓰기
JJJAEOoni
2022. 11. 24. 14:30
반응형
import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import org.junit.Test;
public class FileTest {
@Test
public void test() {
try {
FileOutputStream out = new FileOutputStream("C:/study/test.txt");
String strTextString = "저장해주세요 제발";
out.write(strTextString.getBytes());
out.close();
System.out.println("저장됐겠지..");
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
내용이 바뀌면 똑같은 파일이 덮어쓰기된다.
내용이 똑같아도 이름 바뀌서 또 생성되지 않는다.
import java.io.FileOutputStream;
import java.util.ArrayList;
import java.util.HashMap;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.ss.usermodel.Cell;
import org.apache.poi.ss.usermodel.Row;
import org.junit.Test;
import giosis.web.core.search.model.ModelRows;
public class FileTest2 {
@Test
public void test() {
try {
FileOutputStream out = new FileOutputStream("C:/study/test.xls"); // 파일 경로 수정
// String strTextString = "내용이 변경되었어요";
// out.write(strTextString.getBytes());
HSSFWorkbook wb = new HSSFWorkbook(); //엑셀파일 생성
HSSFSheet sheet = wb.createSheet("result"); //시트 생성
Row row = null; //행 객체 생성
Cell cell = null; //열 객체 생성
//첫 행 입력
row = sheet.createRow(0);
cell = row.createCell(0);
cell.setCellValue("GD_NO");
cell = row.createCell(1);
cell.setCellValue("GD_NM");
cell = row.createCell(2);
cell.setCellValue("NICKNAME");
cell = row.createCell(3);
cell.setCellValue("MGR_NM");
int line = 1; //row번째 행
ArrayList<ModelRows> resultList = new ArrayList<>();
HashMap<String, String> result1 = new HashMap<>();
result1.put("GD_NO", "1");
result1.put("GD_NM", "1");
result1.put("NICKNAME", "1");
result1.put("MGR_NM", "1");
HashMap<String, String> result2 = new HashMap<>();
result2.put("GD_NO", "2");
result2.put("GD_NM", "2");
result2.put("NICKNAME", "2");
result2.put("MGR_NM", "2");
HashMap<String, String> result3 = new HashMap<>();
result3.put("GD_NO", "3");
result3.put("GD_NM", "3");
result3.put("NICKNAME", "3");
result3.put("MGR_NM", "3");
resultList.add(new ModelRows(result1, "Y"));
resultList.add(new ModelRows(result2, "Y"));
resultList.add(new ModelRows(result3, "Y"));
for(int i = 0; i < resultList.size(); i++) {
// quary 결과에서 데이터 가져오기
String gdNo = resultList.get(i).getGdNo();
String gdNm = resultList.get(i).getGdNm();
String nickName = resultList.get(i).getNickName();
String mgrNm = resultList.get(i).getMgrNm();
// 데이터 입력
row = sheet.createRow(line);
cell = row.createCell(0);
cell.setCellValue(gdNo);
cell = row.createCell(1);
cell.setCellValue(gdNm);
cell = row.createCell(2);
cell.setCellValue(nickName);
cell = row.createCell(3);
cell.setCellValue(mgrNm);
line++;
}
wb.write(out);
out.close();
System.out.println("저장됐겠지");
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
해결할 점
1. 서버 로컬이 아니라 클라이언트한테 파일이 저장되어야 한다.
2. 경로를 지정할 수 있어야한다.
반응형