c언어로 파일 탐색기(텍스트 기반)질문이요~
이든샘
질문 제목 :
텍스트 기반 파일 탐색기 를 만드려고 합니다
질문 요약 :
c언어로 텍스트 기반 파일 탐색기를 만들려 하는데
궁금하고 어떻게 해야 될지를 몰라서 부탁드립니다~
질문 내용 :
. 제가 만든 소스는
맨 밑에 사진은 약간 저렇게 까지 아니더라도 gotoxy함수라든가 이런거 써서 탐색기 모양이라도 나타내고 싶은데 어떻게 해야 할줄 몰라서 질문 드립니다. 폴더 생성 이나 삭제 를 하면 계속 보여주는 그런식 으로 하려고 합니다 . 위에는 저렇게 사진처럼 보여주고 아래에다가 ui처럼 생성 및 삭제 수정 하려고 하는데 어떻게 해야 되는지 모르겠습니다.
/* 파일 탐색기
*/
#define _crt_secure_no_deprecate
#include stdio.h
#include stdlib.h
#include windows.h /*디렉토리 생성 삭제 이름변경.*/
#include conio.h
#include tchar.h
#include direct.h//디렉토리 생성 삭제↓
#include sys/stat.h
#include dos.h
int menu;//menu 선택
int back;//메뉴로 돌아갈지, 프로그램을 끝낼지 선택
int rtn;//실행을 성공하였는지 못하였는지
struct entry {
wchar_t *name;
int type ; // 0 : dir, 1: file
int *next[20];
int *parent[20];
};
typedef struct entry entry;
int showmenu()
{
system(cls);
while (1) {
printf( ================ 탐색기 프로그램 ============== \n);
printf( ┃ 1.폴더 생성 ┃ \n);
printf( ┃ 2.폴더 삭제 ┃ \n);
printf( ┃ 3.폴더 이름 수정 ┃ \n);
printf( ┃ 4.폴더 목록보기 ┃ \n);
printf( ┃ 5.끝내기 ┃ \n);
printf( ====================================================== \n);
printf( 원하는 기능의 번호 선택 : );
scanf_s(%d, &menu);
if (menu = 1 && menu = 5) return menu;
}
}
void makefolder()//폴더 생성부분
{
char mkname[100];
while(1)//1.폴더생성
{
printf(\n생성할 폴더의 이름을 입력해주세요.\n);
printf((debug 폴더가 있는 위치에 생성됨.)\n(다른경로를 원할시 직접 입력)\n\n);
scanf_s(%s,&mkname);
// 있는 폴더인지 검사....
if ( 0 == mkdir(mkname)) printf(%s 폴더를 생성하였습니다.\n,mkname);
else
{
printf( 있는 폴더 나 파일입니다. 생성에 실패했습니다.\n);
continue;
}
printf(⇒계속 생성은(1입력)\n⇒menu와 끝내기(2입력)\n);
scanf_s(%d, &back);
if (back == 1)
continue;
if (back == 2)
&nbsbsp; break;
}
}
void rmfolder()
{
char rmname[20];
while(1)
{
printf(삭제할 폴더의 이름을 입력해주세요.\n);
scanf_s(%s,rmname);
rtn = rmdir(rmname);
if( rtn == 0 ) printf(%s 폴더를 삭제하였습니다.\n,rmname);
else
{
printf(%s 폴더를 삭제하지 못하였습니다.\n,rmname);
continue;
}
printf(⇒계속 삭제는(1입력)\n ⇒menu와 끝내기(2입력)\n);
scanf_s(%d, &back);
if (back == 1)
continue;
if (back ==2)
break;
}
}
void rrfolder()
{
char rname[20];
char rrname[20];
while(1)
{
printf(수정하려고 하는 폴더의 이름을 입력해주세요.\n);
scanf_s(%s,rname);
printf(수정할 폴더의 이름을 입력해주세요.\n);
scanf_s(%s,rrname);
rtn = rename(rname,rrname);
if( rtn == 0 ) printf(%s 폴더를 수정하였습니다.\n,rname);
else
{
printf(%s 폴더를 수정하지 못하였습니다.\n,rname);
continue;
}
printf(⇒계속 수정은(1입력)\n⇒menu와 끝내기(2입력)\n);
scanf_s(%d, &back);
if (back == 1)
continue;
if (back ==2)
break;
}
}
bool listdirectorycontents(const wchar_t *sdir)
{
win32_find_dataw fdfile;
handle hfind = null;
wchar_t spath[2048];
wsprintfw(spath, l%s\\*.*, sdir);
if((hfind = findfirstfilew(spath, &fdfile)) == invalid_handle_value)
{
wprintf(lpath not found: [%s]\n, sdir);
return false;
}
do
{
if(wcscmp(fdfile.cfilename, l.) != 0 && wcscmp(fdfile.cfilename, l..) != 0)
{
wsprintfw(spath, l%s\\%s, sdir, fdfile.cfilename);
if(fdfile.dwfileattributes &file_attribute_directory)
{
wprintf(ldirectory: %s\n, spath);
listdirectorycontents(spath);
}
else{
wprintf(lfile: %s\n, spath);
}
}
}
while(findnextfilew(hfind, &fdfile)); //다음파일 을 찾는다.
findclose(hfind);
return true;
}
int main()
{
while(1)
{
menu = showmenu();
switch (menu) {
case 1:
makefolder(); //디렉토리를 보여준다.
printf(⇒가장 처음의 menu로(1입력)\n);
printf(끝내기.(2입력)\n);
scanf_s(%d, &back);
if (back == 1)
continue;
if (back ==2)
break;
case 2:
rmfolder(); //디렉토리 삭제
printf(⇒가장 처음의 menu로(1입력)\n);
printf(끝내기.(2입력)\n);
scanf_s(%d, &back);
if (back == 1)
continue;
if (back ==2)
break;
case 3:
rrfolder(); //디렉토리 수정
printf(⇒가장 처음의 menu로(1입력)\n);
printf(끝내기.(2입력)\n);
scanf_s(%d, &back);
if (back == 1)
continue;
if (back ==2)
break;
case 4:
listdirectorycontents(lc:\users\dot_z\desktop\jaeyoung\2.이산수학\project\파일탐색기1\파일탐색기1); //디렉토리 목록 보기
printf(⇒가장 처음의 menu로(1입력)\n);
printf(끝내기.(2입력)\n);
scanf_s(%d, &back);
if (back == 1)
continue;
if (back ==2)
break;
case 5:
retbsp; return 0;
default:
printf(잘못된 메뉴입니다.\n);
}
break;
}
return 0;
}
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2692230 | 하노이탑 질문입니다. (1) | 미쁘다 | 2025-04-21 |
2692210 | 정보 올림피아드 문제인데.. 풀이 과정이 궁금합니다.(재귀함수) (5) | 물티슈 | 2025-04-20 |
2692144 | C언어와 리눅스에 대한 질문입니다. | 싴흐한세여니 | 2025-04-20 |
2692114 | 컨텍스트 스위칭하는데 걸리는 시간 측정.. | YourWay | 2025-04-19 |
2692086 | 간접참조 연산자, 증감연산자 질문이용! (2) | 블랙캣 | 2025-04-19 |
2692056 | 주석좀 달아주세요. 몇개적엇는데 몇개만달아주세요. (2) | DevilsTears | 2025-04-19 |
2691978 | 진수 쉽게 이해하는법... (3) | 지지않는 | 2025-04-18 |
2691949 | getchar() 한 문자를 입력받는 함수 질문 | 채꽃 | 2025-04-18 |
2691919 | 배열 정렬 및 합치기 질문입니다. | 사과 | 2025-04-18 |
2691845 | c언어왕초보 질문이 있습니다........ | 루나 | 2025-04-17 |
2691815 | void add(int num); 함수... (4) | 살랑살랑 | 2025-04-17 |
2691756 | 명령 프롬프트 스크롤바가 없어요 | 두메꽃 | 2025-04-16 |
2691725 | 자료구조에 관련해서 질문이 있어 글을 올립니다. | 누리알찬 | 2025-04-16 |
2691697 | if 문에서 구조체 배열에 저장되있던 문자열 검사하는 법 ? (2) | 민트맛사탕 | 2025-04-16 |
2691678 | C언어 함수 질문이요~!!! | 연보라 | 2025-04-15 |
2691650 | 반복문 | 돋가이 | 2025-04-15 |
2691618 | 링크드리스트 개념 질문이예요 (3) | 맨마루 | 2025-04-15 |
2691592 | 동적할당 이용 배열선언 질문입니다.ㅠㅠ (3) | 허리달 | 2025-04-15 |
2691542 | /=의 용도를 알려주세요 ㅠㅠ! (2) | 아라 | 2025-04-14 |
2691510 | sizeof 연산자 질문입니다 (2) | 종달 | 2025-04-14 |