투케이2K

465. (kotlin/코틀린) [유틸 파일] : directoryFileList : 특정 디렉토리에 저장된 파일 리스트 목록 확인 - File listFiles 본문

Kotlin

465. (kotlin/코틀린) [유틸 파일] : directoryFileList : 특정 디렉토리에 저장된 파일 리스트 목록 확인 - File listFiles

투케이2K 2024. 4. 1. 19:39
반응형

[개발 환경 설정]

개발 툴 : AndroidStudio

개발 언어 : Kotlin

 

[소스 코드]

        // -----------------------------------------------------------------------------------------
        // TODO [SEARCH FAST] : [RETURN] directoryFileList : 특정 디렉토리에 저장된 파일 리스트 목록 확인
        // -----------------------------------------------------------------------------------------
        fun directoryFileList(mContext: Context, path: String): ArrayList<File> {

            /**
             * // -----------------------------------------
             * [directoryFileList 메소드 설명]
             * // -----------------------------------------
             * 1. 특정 디렉토리에 저장된 파일 리스트 목록 확인
             * // -----------------------------------------
             * 2. 호출 방식 :
             *
             * C_App.directoryFileList(A_Main@this, Environment.getExternalStoragePublicDirectory(Environment.DIRECTORY_DOWNLOADS).absolutePath)
             *
             * // -----------------------------------------
             * 3. 리턴 데이터 : [/storage/emulated/0/Download/test.dat, /storage/emulated/0/Download/test.apk]
             * // -----------------------------------------
             * 4. 추가로 외부 저장소에 파일 읽기 및 쓰기를 위해서 Manifest 권한 필요 및 인텐트 이동 수행
             *
             * 권한 : <uses-permission android:name="android.permission.MANAGE_EXTERNAL_STORAGE"></uses-permission>
             *
             * 인텐트 이동 : Settings.ACTION_MANAGE_APP_ALL_FILES_ACCESS_PERMISSION
             * // -----------------------------------------
             * 5. 참고 설명 :
             *
             * 해당 권한을 추가 시 마켓에 특정 용도로 사용하는 앱 목적을 밝혀야합니다 (앱 등록 및 업데이트 리젝 될 수 있습니다)
             *
             * 외부 저장소 경로 : /storage/emulated/0
             * // -----------------------------------------
             */


            // [리턴 값 선언]
            val returnData = ArrayList<File>()
            var M_LOG = ""


            // [로직 처리 실시]
            M_LOG = try {

                // [데이터 널 체크]
                if (C_Util.stringNotNull(path) === true) {

                    // [File 생성]
                    val file = File(path)

                    // [해당 디렉토리 존재 확인]
                    if (file.isDirectory == true) {

                        // [파일 리스트 확인]
                        val list = file.listFiles()
                        if (list != null && list.size > 0) {

                            // [리턴 데이터 삽입]
                            returnData.addAll(Arrays.asList(*list))
                            "[SUCCESS] : File List Check"

                        } else {
                            "[ERROR] : File List Is Null"
                        }
                    } else {
                        "[ERROR] : Directory Is Null"
                    }
                } else {
                    "[ERROR] : Input Path Is Null"
                }

            } catch (e: Exception) {
                S_Log._printStackTrace_(mContext, S_FinalMsg.LOG_BUG_STATE, null, e)
                "[EXCEPTION] : " + e.message.toString()
            }


            // [로그 출력 실시]
            // ===============================================================
            S_Log._D_("특정 디렉토리에 저장된 파일 리스트 목록 확인", arrayOf(
                "INPUT [PATH] :: $path",
                "M_LOG :: $M_LOG",
                "RETURN :: $returnData"
            ))
            // ===============================================================


            // [리턴 반환 실시]
            return returnData
        }
 

[결과 출력]

 

D///===========//: ================================================
I/: [LOG :: CLASS PLACE :: com.example.kotlinproject.C_App.directoryFileList]
I/: ----------------------------------------------------
I/: [LOG :: NOW TIME :: 2024-04-01 15:05:21 월요일]
I/: ----------------------------------------------------
I/: [LOG :: DESCRIPTION :: 특정 디렉토리에 저장된 파일 리스트 목록 확인]
I/: ----------------------------------------------------
I/: [LOG :: INPUT [PATH] :: /storage/emulated/0/Download]
I/: ----------------------------------------------------
I/: [LOG :: M_LOG :: [SUCCESS] : File List Check]
I/: ----------------------------------------------------
I/: [LOG :: RETURN :: [/storage/emulated/0/Download/test.dat]]
D///===========//: ================================================

 

반응형
Comments