Develop
2015.11.10 15:49
[c] 한글 문자열 출력
조회 수 1667 댓글 0
영어는 1byte, 한글은 2byte 차지한다.
따라서 문자열 처리할 때 한 포인터씩 출력을 하게 되면 한글이 깨지는 현상이 발생한다.
예를 들어 한글과 영어가 섞여있는 문자열을 출력할 때 다음과 같은 소스를 이용하면 한글이 깨져서 출력된다.
#include <stdio.h> #include <stdlib.h> const int MAX_SIZE = 1000; int main(){ FILE *fp = fopen("test.txt","r"); char* inp = (char*)malloc(sizeof(char)*MAX_SIZE); int i; while(fgets(inp, MAX_SIZE, fp)){ printf("%s" , inp); for(i = 0 ; i < strlen(inp) ; i++){ printf("%c " , inp[i]) ; } printf("\n"); } return 0; }
그렇다면, 한글과 영어를 판단해서 영어는 1byte, 한글은 2byte를 출력해야 할텐데,
어떻게 하면 한글인지 영어인지 확인할 수 있을까?
#include <stdio.h> #include <stdlib.h> const int MAX_SIZE = 1000; typedef enum {false, true} bool; int main(){ FILE *fp = fopen("test.txt","r"); char* inp = (char*)malloc(sizeof(char)*MAX_SIZE); int i; bool HANGUL = false; while(fgets(inp, MAX_SIZE, fp)){ printf("%s" , inp); for(i = 0 ; i < strlen(inp) ; i++){ if((inp[i] & 0x80) == 0x80) HANGUL = true; //한글인지 확인 if(!HANGUL)printf("%c " , inp[i]) ; //아니면 그냥 출력 else{ printf("%c%c" , inp[i] , inp[i+1]); //한글이면 2byte 출력 i++; } HANGUL = false; } printf("\n"); } return 0; }
위의 소스는 각 char 마다 한글인지 아닌지를 판단해서 한글인 경우 2byte를 출력하게 해준다.
번호 | 분류 | 제목 | 글쓴이 | 날짜 | 조회 수 |
---|---|---|---|---|---|
757 | Develop | [php] 정규표현식 간단히 정리 | hooni | 2013.04.23 | 6451 |
756 | Develop | [php] 자주 쓰는 PHP 함수와 예제 | hooni | 2013.04.23 | 9700 |
755 | Develop | [php] 자바스크립트 개판 만들기.. | hooni | 2013.04.23 | 7649 |
754 | Develop | [php] 이미지 회전시키기(gd) | hooni | 2013.04.23 | 7306 |
753 | Develop | [php] 웹 터미널 & 업로드 소스.. | hooni | 2013.04.23 | 7216 |
752 | Develop | [php] 웹 응용프로그램(engines) 모음 | hooni | 2013.04.23 | 7513 |
751 | Develop | [php] 심플한 게시판 ㅋㅋ 1 | hooni | 2013.04.23 | 12978 |
750 | Develop | [php] 쉘에서 실행할 때 인수(파라미터) 받기.. | hooni | 2003.04.23 | 11588 |
749 | Develop | [php] 서버 이상 체크 해서 문자보내는 샘플소스.. | hooni | 2013.04.23 | 6691 |
748 | Develop | [php] 빔 프로젝터 예약 프로그램.. ㅋㅋ | hooni | 2013.04.23 | 6912 |
747 | Develop | [php] 배열 관련 함수 설명 ㅎㅎ | hooni | 2003.04.23 | 11742 |
746 | Develop | [php] 무조건 다운로드 받도록 header 세팅 | hooni | 2013.04.23 | 7378 |