본문 바로가기
자바스크립트

[자바스크립트] 문자열 배열로 자르기 (split 함수)

by 세바개님 2023. 3. 15.

JavaScript의 split() 함수는 문자열을 특정 구분자(delimiter)를 기준으로 나누어 배열로 반환하는 함수입니다. 이 함수는 다양한 상황에서 사용될 수 있으며, 문자열을 처리하고 분석하는 데 유용합니다.

 

1. 설명


split() 함수는 다음과 같은 구문을 가집니다.

 

string.split(separator, limit)


split() 함수는 두 개의 매개변수를 가질 수 있습니다.

  • separator: 필수 매개변수로, 문자열을 나눌 기준이 되는 구분자입니다. 이 매개변수는 문자열 또는 정규표현식으로 지정할 수 있습니다. 만약 생략된 경우, 문자열 전체가 하나의 배열 요소로 반환됩니다.
  • limit: 선택적 매개변수로, 반환할 배열 요소의 최대 개수를 지정합니다. 이 매개변수가 생략된 경우, 배열은 구분자로 나눠진 모든 요소를 포함합니다.

 

2. 예제 코드

 

split() 함수를 사용하여 문자열을 나누는 예제를 살펴보겠습니다.

 

const str = 'apple, banana, kiwi, orange';
const fruits = str.split(', ');

console.log(fruits);
// ["apple", "banana", "kiwi", "orange"]


위 예제에서는 , (쉼표와 공백)을 구분자로 사용하여 문자열을 나누어 fruits 배열에 저장합니다. 결과적으로 fruits 배열에는 "apple", "banana", "kiwi", "orange" 네 개의 요소가 포함됩니다.

정규표현식을 사용하여 split() 함수를 사용하는 예제를 살펴보겠습니다.

 

const str = 'hello, world!';
const words = str.split(/\W+/);

console.log(words);
// ["hello", "world"]


위 예제에서는 \W+ 정규표현식을 구분자로 사용하여 문자열을 나누어 words 배열에 저장합니다. \W+는 알파벳, 숫자, 밑줄 문자가 아닌 모든 문자를 구분자로 사용하도록 지정합니다. 따라서 결과적으로 words 배열에는 "hello"와 "world" 두 개의 요소가 포함됩니다.

 

3. 주의 사항

 

split() 함수를 사용할 때 주의해야 할 몇 가지 사항이 있습니다.


1) 구분자로 빈 문자열을 사용하는 경우


구분자로 빈 문자열을 사용하는 경우, 문자열을 한 글자씩 잘라 배열에 저장합니다. 이 경우 문자열이 길 경우 많은 수의 배열 요소가 생성될 수 있어 성능에 영향을 미칠 수 있습니다.

 

2) 구분자를 생략하는 경우


구분자를 생략하는 경우, 문자열 전체가 하나의 배열 요소로 반환됩니다. 이 경우 문자열을 잘못 처리하는 경우가 있을 수 있으므로 구분자를 명시적으로 지정하는 것이 좋습니다.

 

3) 문자열이 null 또는 undefined인 경우


split() 함수는 문자열이 null 또는 undefined인 경우 TypeError를 발생시킵니다. 따라서 문자열이 null 또는 undefined인 경우 먼저 검사해야 합니다.

 

4) split() 함수가 호출된 객체가 문자열이 아닌 경우


split() 함수는 문자열에 대해서만 호출 가능합니다. 만약 문자열이 아닌 객체에서 split() 함수를 호출하는 경우 TypeError를 발생시킵니다.
따라서 split() 함수를 사용할 때는 위와 같은 상황에 대해 주의해야 합니다.

댓글