fwrite() 함수에 대해 살펴보겠습니다.
fwrite() 함수는 어떤 파일에 그 함수의 인자로 주어진 문자열을 쓰게 해주는 역할을 합니다.
그럼, 아래 예제 코드를 통해 fwrite() 함수의 사용법을 보겠습니다.
<?
$file_pointer = fopen("./data.txt", "w");
$text = "Good Morning";
fwrite($file_pointer, $text);
fclose($file_pointer);
?>
위 예제를 통해 볼 수 있듯이, 파일에 쓰기 동작을 하기 전에 fopen() 함수를 사용하여 파일 열기를 하였는데, 이때 파일 열기 모드를 쓰기 모드 즉, "w" 로 기술한 것을 볼 수 있습니다.
쓰기 모드에 해당되는 "w" 모드는 파일을 쓰기 모드로 열으라는 의미를 가지며, 만일 fopen() 함수의 첫 번째 인자로 오는 파일이 해당 폴더에 없을 경우에는 새로 그 명시된 파일을 생성하게 됩니다.
따라서, 위의 예제 코드를 웹브라우저로 확인하기 전에 굳이 위에서 명시한 "data.txt" 파일을 생성해 줄 필요가 없습니다.
다음으로, 위와 같이 파일 열기를 한 후에, $text 변수에 "Mizzle PHP" 를 저장한 다음 fwrite() 함수를 사용하여 $file_pointer 가 가리키는 파일 즉, "data.txt" 파일에 $text 변수에 저장된 문자열을 쓰는 것을 볼 수 있습니다.
이제 실제로 위 예제 코드를 웹브라우저를 통해 실행해보면 data.txt 파일에 Mizzle PHP 라는 문자열이 저장된 것을 볼 수 있습니다.(웹브라우저에는 아무것도 출력되지 않겠죠.)
그럼, 현재 "data.txt" 파일에 "Good Morning" 문자열이 저장된 상태에서 그 다음 줄에 새로운 문자열을 쓰려면 어떻게 해야 할까요?
먼저, fopen() 함수의 열기 모드를 명시할 때, 또 다른 쓰기 모드인 "a" 모드로 명시해 주어야 합니다.
아래의 예제를 볼까요?
<?
$file_pointer = fopen("./data.txt", "a");
$text = chr(10) . "Good Evening";
fwrite($file_pointer, $text);
fclose($file_pointer);
?>
위와 같이, 첫 번째 예제에 사용하였던 "data.txt" 파일을 "a" 모드로 열기를 하였는데,
"a" 모드는 파일을 쓰기 모드로 열며, 이때 파일의 쓰기 포인터를 그 안에 저장된 내용물의 맨 마지막에 위치시키는 역할을 합니다.
따라서, 위 예제 코드의 세 번째 줄에 보이는 fwrite() 함수에 의해 새로운 문자열을 그 파일에 쓰기를 하면 첫 번째 예제의 실행 결과로 저장된 "Good Morning" 문자열 다음부터 쓰여지게 됩니다.
그런데, 위에 보시면, $text 변수에 "Good Evening" 문자열과 더불어 앞에 chr(10) 이 붙은 것을 볼 수 있죠.
그게 붙은 이유는, 우리가 두 번째 예제를 통해 하고자 하는 것이 현재 파일에 들어 있는 문자열 바로 다음 줄 부터 쓰기를 해야 하는데, 이때 chr(10) 이 다음 줄로 쓰기 포인터를 옮겨주는 역할을 하기 때문입니다.
따라서, 위 두 번째 예제를 웹브라우저를 통해 확인하면 "data.txt" 파일 안에는 다음과 같은 내용물이 저장된 것을 볼 수 있습니다.
Good Morning
Good Evening
게시글 목록
| 번호 | 제목 |
|---|---|
| 11913 | |
| 20339 | |
| 11912 | |
| 11909 |
JavaScript
Ajax 로 받은 Json 값을 View 형식에 맞춰 표현
2
|
| 11908 | |
| 11890 | |
| 11887 | |
| 11886 | |
| 17743 | |
| 11885 |
MySQL
MYSQL 쿼리순서, 부하여부 질문드려요
|
| 17742 | |
| 11884 | |
| 11883 | |
| 20338 | |
| 11880 |
node.js
mysql 연결 방법 2가지
2
|
| 11876 |
JavaScript
한글로 된 숫자를 아라비아 숫자로 변환
3
|
| 11874 | |
| 11873 | |
| 20334 | |
| 11872 |
jQuery
제이쿼리로 이미지 회전 시키기
|
| 11869 |
jQuery
구형 익스에서 HTML5 적용시키기
2
|
| 11867 |
jQuery
특정 레이어 높이 100% 잡는 법
1
|
| 20333 | |
| 11865 |
jQuery
모바일 해상도에 맞게 이미지 출력
1
|
| 11864 |
댓글 작성
댓글을 작성하시려면 로그인이 필요합니다.
로그인하기