티스토리 뷰
FileTreeWalk
Kotlin의 Sequence interface를 구현한 class이며 file traversal에 관련된 기능들을 제공한다.
kotlin에서 제공하는 iterator, sequence관련 extension과 함께 사용하면 다양한 원하는기능들을 매우 쉽게 구현할수 있다.
기본적으로 File에대한 extension으로 walk(default : top-down), walkTopDown, walkBottomUp의 형태로 사용가능하다 당연히 DFS(깊이 우선 탐색)의 형태로 구현되어있다. Kotlin extension인 filter를 사용해서 구현한 간단한 예제 2가지를 구현해 보았으며 이외에도 손쉽게 원하는 기능을 구현할 수 있을 것이다.
Example - root 폴더 내의 모든 디렉토리 조회
fun getAllDirectories(root:File) : List
{
return root.walk().filter { it.isDirectory }.toList()
}
Example - root 특정 타입 파일 조회
fun getAllFilesExt(root:File, ext:String) : List
{
return root.walk().filter { it.extension.equals(ext) }.toList()
}
'Dev > Kotlin' 카테고리의 다른 글
Kotlin_Sequence vs Iterator (0) | 2017.11.08 |
---|---|
Kotlin Overview (0) | 2017.10.13 |
댓글
공지사항
최근에 올라온 글
최근에 달린 댓글
- Total
- Today
- Yesterday
TAG
- 삼항연산자
- mysql
- 행렬
- Math
- robocopy
- Highlighter
- 수식
- 도메인
- Android
- Bit
- Kotlin
- syntax highlighting
- 안드로이드
- algorithm
- highlightjs
- 비트연산자
- DNS
- mathjax
- 비트마스크
- Matrix
- 비트
- C
- python
- 알고리즘
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | 5 | 6 | |
7 | 8 | 9 | 10 | 11 | 12 | 13 |
14 | 15 | 16 | 17 | 18 | 19 | 20 |
21 | 22 | 23 | 24 | 25 | 26 | 27 |
28 | 29 | 30 |
글 보관함