Scala에서 하위 배열을 얻는 올바른 방법은 무엇입니까?


94

나는 스칼라에서 하위 배열을 얻으려고 노력하고 있으며 적절한 방법이 무엇인지에 대해 약간 혼란 스럽습니다. 내가 가장 원하는 것은 파이썬에서 어떻게 할 수 있는지와 같은 것입니다.

x = [3, 2, 1]
x[0:2]

하지만 나는 당신이 이것을 할 수 없다고 확신합니다.

이를 수행하는 가장 확실한 방법은 Java Arrays util 라이브러리를 사용하는 것입니다.

import java.util.Arrays
val start = Array(1, 2, 3)
Arrays.copyOfRange(start, 0, 2)

그러나 Scala에서 Java 라이브러리를 사용하는 것은 항상 나를 조금 더럽게 만듭니다. 내가 찾은 가장 "scalaic"방법은

def main(args: List[String]) {
    val start = Array(1, 2, 3)
    arrayCopy(start, 0, 2)
}
def arrayCopy[A](arr: Array[A], start: Int, end: Int)(implicit manifest: Manifest[A]): Array[A] = {
    val ret = new Array(end - start)
    Array.copy(arr, start, ret, 0, end - start)
    ret
}

하지만 더 좋은 방법이 있습니까?

답변:


130

slice 메서드를 호출 할 수 있습니다.

scala> Array("foo", "hoo", "goo", "ioo", "joo").slice(1, 4)
res6: Array[java.lang.String] = Array(hoo, goo, ioo)

파이썬 에서처럼 작동합니다.


2
아, 물론 ArrayOps scala-lang.org/api/current/scala/collection/mutable/… , 나는 바보입니다.
nnythm

네 말이 맞아. 나는 구속 된 관습을 언급하고 있었다. 하한이 포함되고 상한이 제외됩니다. 후행 :도 없습니다.
패러다임

13

a~ 부터 까지의 요소가있는 배열이 있다고 상상해보세요.f

scala> val array = ('a' to 'f').toArray // Array('a','b','c','d','e','f')

그런 다음 다른 방법으로 하위 배열을 추출 할 수 있습니다.

  1. 처음 n 개의 첫 번째 요소 삭제 drop(n: Int)

    array.drop(2) // Array('c','d','e','f')

  2. 처음 n 개의 요소를 take(n: Int)

    array.take(4) // Array('a','b','c','d')

  3. 를 사용하여 요소 간격을 선택합니다 slice(from: Int, until: Int). 참고 until제외됩니다.

    array.slice(2,4) // Array('c','d')

    slice 메서드는 다음과 완전히 동일합니다.
    array.take(4).drop(2) // Array('c','d')

  4. 다음을 사용하여 마지막 n 개 요소를 제외합니다 dropRight(n: Int).

    array.dropRight(4) // Array('a','b')

  5. 다음을 사용하여 마지막 n 개 요소를 선택합니다 takeRight(n: Int).

    array.takeRight(4) // Array('c','d','e','f')

참조 : 공식 문서


1

2D Scala Array (original_array)에서 특정 열을 추출하는 예 :

import scala.collection.mutable.ArrayBuffer

val sub_array = ArrayBuffer[Array[String]]()
val columns_subset: Seq[String] = Seq("ColumnA", "ColumnB", "ColumnC")
val columns_original = original_array(0)

for (column_now <- columns_subset) {
      sub_array += original_array.map{_(columns_original.indexOf(column_now))}
    }
sub_array
당사 사이트를 사용함과 동시에 당사의 쿠키 정책개인정보 보호정책을 읽고 이해하였음을 인정하는 것으로 간주합니다.
Licensed under cc by-sa 3.0 with attribution required.