~~Title:PHP 배열~~
{{page>language:php:php_문서_목차&noheader&nofooter&noeditbtn&firstseconly}}
====== 배열 ======
$VarName[ Key ] = Value.
Key는 배열의 인덱스. 또한 Key는 숫자 또는 문자열이 가능하다.
===== 배열 만들기 =====
$_ar = array(); // 빈 배열 만들기
$_ar = array( ‘a’, ‘b’, ‘c’ );
$_ar = range( 1, 10 ); // 1부터 10까지 값을 가지는 배열
$_ar = range( 1, 10, 2 ); // 1부터 10까지 홀수의 배열
$_ar = range( ‘a’, ‘z’ ); // 영문자 a ~ z까지의 배열
배열은 따로 선언하지 않아도, 사용하는 즉시 만들어진다.
===== 배열 내용 출력 =====
1, 4 => 1, 19, 3 => 13);
print_r($array);
?>
===== 숫자 인덱스 =====
| 값을 사용하기 | $_ar[ 0 ]; // 괄호 사이에 인덱스 번호
|
| 값을 대입하기 | $_ar[ 0 ] = ‘NewValue’;
|
===== 내용 확인하기 =====
echo “$_ar[0] $_ar[1]”; // “...” 사이의 변수들은 실제 값으로 사용(출력)된다.
===== 루프에서 배열 사용하기 =====
for( $i = 0; $i < 3; $i++ ) { echo $_ar[ $i ] . “ “; }
foreach( $_ar as $var ) { echo $var . “ “; } // foreach( <배열> as <배열항목> ) 구문 참고.
===== 문자열을 Key 값으로 사용 =====
$_ar2 = array( ‘A’ => 10, ‘B’ => 20 );
//(or)
$_ar2 = array( ‘A’ => 10 );
$_ar2[ ‘B’ ] = 40;
// 배열 생성 후 임의로 ‘B’ 항목 추가
===== 루프에서 배열 사용하기 =====
for 문은 사용 불가능...? 다른 방법이 있을 듯.
foreach / list / each 를 사용한다.
==== foreach 문장 ====
$_ar2의 배열을 foreach 문을 사용해서 처음부터 순차적으로 사용한다.
* $_key는 배열의 키 (키를 정하지 않으면 0으로 시작되는 숫자 인덱스)
* $_value 배열의 값이다.
foreach( $_ar2 as $_key => $_value )
{
echo $_key . “ - “ . $_value . “
”;
}
**중요**
$_value로 전달되는 값은 참조(레퍼런스)가 아닌 값의 복사이므로, \\ 배열과 같이 참조형으로 전달될 필요가 있는 경우에는 '&'를 사용해서 참조라고 명시해야 한다.
// $_ar2는 배열을 값으로 갖는 배열
$_ar2 = Arary( Array('a','b'), Array('c','d') );
// 값의 변경이 바로 반영되기를 원하는 경우에는 참조로 값을 넘겨야 한다.
foreach( $_ar2 as $_key => &$_value )
{
echo $_key . “ - “ . $_value . “
”;
}
====== each 함수 ====
while( $_elem = each( $_ar2 ) )
{
echo $_elem[ ‘key’ ];
echo $_elem[ ‘value’ ];
}
==== list 함수 ====
while( list( $_a, $_b ) = each( $_ar2 ) ) { ….. }
// $_a : Key, $_b = Value
===== 다차원 배열 =====
2차원 이상의 배열을 사용할 수 있다. 코드 상으로는 3, 4도 가능하겠으나... 실용성은 적겠지.
$_ar3 =
( array( ‘1-1’, ‘1-2’, ‘1-3’ ),
array( ‘2-1’, ‘2-1’, ‘2-2’ ) );
===== 배열을 다루는 함수들 =====
| reset() | each()로 변경된 배열의 위치를 처음으로 되돌린다. |
| sort() | 배열을 정렬한다. |
| ::: | SORT_REGULAR : 내림차순 |
| ::: | SORT_NUMERIC : ? |
| ::: | SORT_STRING : ? |
| asort() / arsort() | 문자열 인덱스 배열 정렬시, 요소의 값에 따라 정렬. asort()는 역으로 정렬. |
| ksort() / krsort() | 문자열 인덱스 배열 정렬시, 배열키를 알파벳 순서대로 정렬. krsort()는 역으로 정렬. |
| usort() | usort( 배열변수, ‘함수이름’ ) \\ 개발자 임의로 Custom 정렬하는 기능을 사용하려고 할때 사용. \\ 다차원배열과 같이 일반 함수로는 정렬할 수 없는 경우, Custom 정렬함수를 추가해서 배열을 정렬한다. |
| shuffle() | 배열섞기 |
| array_reverse() | 배열을 역순으로 만들어서 리턴(?) |
| array_push() | 배열의 끝에 항목추가 ( 앞이 아닌가? ) |
| array_pop() | 배열의 끝에서 얻고 삭제 |
| array_reverse() | array_reverse( $_var ), 복사본을 리턴하고 원본은 유지. |
| range() | 배열을 생성 |
| ::: | range( 시작, 종료값, 증가분 ) |
| ::: | range( 10, 1, -1 ) -> 10 .. 1 까지의 숫자 배열 |
| explode() | 토큰을 얻는 함수. |
| ::: | explode( STRING _seperator, STRING _string, int limit ) |
| ::: | _string을 _seperator 단위로 끊어서 배열로 저장한다. |
===== 배열을 탐색할때 사용하는 함수들 =====
| intval() | 문자열을 숫자로 변경 |
| current() | current( $_ar ); 배열의 현재 위치의 값 리턴 |
| each(), next() | 배열의 현재 위치를 하나씩 앞으로 (다음으로) 이동 |
| end() | 배열의 끝으로 이동 |
| prev() | 배열의 위치를 움직인 다음에 값을 리턴 |
===== 배열의 각 요소들에 일괄적인 처리를 하고 싶은 경우( 각 요소에 함수 적용? ) =====
모든요소를 사용해야하거나 같은 방식으로 요소를 모두 수정하려고 하는 경우,
array_walk( array _ar, string func, mixed )
func는 임의의 custom 함수로,
customFunc( value, key, userData ) 의 형식을 갖는다.
===== 배열 개수 =====
| count() \\ sizeof() | 배열의 개수 |
| array_count_values() | 배열상에서, 같은 요소를 가진 것들로 다시 배열을 만들어서 리턴 \\ array( 1, 1, 3, 4, 5, 5, 5 ) --> 이 함수를 사용하면 \\ array( 1 => 2, 3 => 1, 4 => 1, 5 => 3 ) 가 나온다. (확인필요) |
| extract() | 배열의 키를 변수로 만들어준다. |
====== 배열에서 특정 값이 있는지 찾기 ======
* [[https://www.php.net/manual/en/function.in-array.php|in_array]]