티스토리 뷰
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
- highlightjs
- Bit
- 도메인
- Math
- python
- 비트연산자
- 삼항연산자
- mathjax
- 비트마스크
- Android
- 알고리즘
- Matrix
- algorithm
- syntax highlighting
- Kotlin
- 안드로이드
- 행렬
- Highlighter
- C
- robocopy
- 수식
- 비트
- DNS
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
글 보관함