str_replace, substr ,strpos, explode

\d – 메타문자는 0-9까지의 숫자위치확인
\w – a~z 알파벳 대소문자의 위치를확인
\s – 띄어쓰기를 확인
^  – 문자열의 시작
$ – 문자열의 마지막

/\d{10}/  -패턴에서 {10} 가 수량자
{최소,최대} -반복을 나타냄
+  -반드시 1회이상 등장 의미
* – 1회또는 그 이상 등장해고 상관없음
? – 1회또는 아예 등장하지 말아할것
[a-d] -소문자 a 에서부터 a b c d 까지만 허용
[^a-d] -삿갓은 문자열의 시작 -하지만 문자열클래스에서는 허용 하지않겠다는 의미(a b c d 를 허용 안함)

1. 먼저 문자열을 정리하는 함수입니다.
$result = trim($string) – 문자열 앞,뒤 에있는 공백문자를 지웁니다.
$result = ltrim($string) – 문자열 앞에 들어가는 공백문자를 지웁니다.
$result = chop($string) – 문자열 뒤에 들어가는 공백문자를 지웁니다.

공백문자 – 줄바꿈 개행문자, 탭문자, 스페이스 등의 안보이는 문자

$result = nl2br($string) – 문자열에 포함된 줄바꿈(\r,\n) 문자를 <br> 태그로 변환합니다. (php 버전이 4.0.6 보다 낮을경우 <br> 높을경우 <br/>)

2. 대소문자 변경

$result = strtoupper($string) – 문자열을 대문자로 모두 바꿔줍니다.
$result = strtolower($string) – 문자열을 소문자로 모두 바꿔줍니다.
$result = ucfirst($string) – 문자열의 첫단어가 영문자이면 그것만 대문자로 바꿔줍니다.
$result = ucword($string) – 문자열 각단어의 첫 영문자를 대문자로 바꿔줍니다.

3. 문자열 길이

$result = strlen($string) – 문자열의 길이값이 $result 에 저장됩니다. (결과값:정수형)

4. 문자열 대체

$result = str_replace($str1, $str2, $원본문자열) – 원본문자열에서 $str1 을 찾아 $str2 로 바꿔서 $result 에 저장합니다. 문자 or 문자열 다 가능합니다.
$result = substr_replace($원본문자열, $str1, $위치) – 원본문자열의 $위치 에 있는 문자를 $str1 로 바꿔서 $result 에 저장합니다.

예제) $result = str_reaplce(“가나다”,”ABC”,”가나다라마바사”); 결과값 $result = “ABC라마바사”
$result = substr_reaplce(“ABCDEF”,”XYZ”,2); 결과값 $result = “ABXYZDEF” , 인덱스 2의 단어(0부터시작) C -> XYZ 로 바뀝니다.

5. 문자열 비교

$result = strcmp($str1,$str2) – $str1 과 $str2 두 문자열을 비교합니다. 각 문자열의 인덱스 순서대로 비교하는데 정확히 일치하면 0 을 반환하고
$str1 이 더 길거나 ASCII 값이 더 크다면 양수(+), $str2 가 더 길거나 ASCII 값이 더 크다면 음수(-)를 반환합니다.

$result = strcasecmp($str1,$str2) – strcmp와 기능은 같은데 차이점은 대소문자 구분을 하지않는다는 것입니다.
일반적으로 소문자가 ASCII 값이 더 큰데, 그걸 따지지않고 같은 레벨로 비교합니다.

6. 문자열찾기

$result = strstr($원본문자열, $찾을문자열) – $원본문자열 에서 $찾을문자열을 찾는 함수입니다.
찾는 문자열이 있을경우 결과값 $result 에는 찾는 문자열을 포함해서 그 뒤의 문자열이 저장됩니다.
찾는 문자열이 없을경우 결과값 $result 에는 false (boolean) 값이 저장됩니다. 논리연산(!== , ===) 필요.

예제) $result = strstr(“가나다라마바사”, “다라”); 결과값 $result = “다라마바사”

$result = stristr($원본문자열, $찾을문자열) – strstr 함수와 기능이 같습니다. 단, 대소문자 구분을 하지않습니다.

$result = strchr(($원본문자열, $찾을문자) – $원본문자열 에서 $찾을문자를 찾는 함수입니다. 결과값은 strstr 과같습니다.

$result = strrchr(($원본문자열, $찾을문자) – $원본문자열의 뒷부분 부터 $찾을문자를 찾는 함수입니다. 결과값은 strstr과 같습니다.

7. 문자열 내의 위치찾기

$result = strpos($원본문자열, $찾을문자열) – $원본문자열 에서 $찾을문자열을 찾는 함수입니다.
strstr 과 기능은 같으나 결과값이 $원본문자열의 정수형 인덱스입니다.(0 부터시작)
찾을문자열이 없는경우 false 를 리턴합니다.
찾을문자열이 원본문자열의 맨처음에 있는경우 결과값은 0 입니다.
단순비교연산자를 쓰면 0 , false 모두 같은값으로 간주하기때문에 주의하셔야됩니다. (아래 주의 참고)

주의) strpos 등의 문자나 문자열을 찾는 함수의 경우 , 찾지 못했을때 결과값은 false입니다.
PHP 에서 == 등의 비교연산은 0 , false 모두 0 으로 간주하기때문에 이때는 논리비교연산(=== , !==)을 써야됩니다.
$result === false (0)  , $result == false (X)
$result !== false (0) , $result != false (X)

예제) $result = strpos(“가나다라마바사”,”라”); 결과값 $result = 3

$result = strrpos($원본문자열, $찾을문자) – $원본문자열의 뒷부분 부터 $찾을문자를 찾는 함수입니다.
strrpos는 찾을문자열 대신 찾을문자만 써야됩니다. 결과값은 strpos와 같습니다.

8. 문자열 자르기

$result = substr($원본문자열, $찾을위치, $갯수) – $원본문자열에서 $찾을위치의 인덱스로부터 $갯수만큼의 문자열을 잘라서 반환합니다.
다양한 방법으로 활용할 수 있습니다.

예제)
$original_str = “It’s hard to be in other’s shoes.”;
$result = substr($original_str, 5) -> $result = “hard to be in other’s shoes.” , 맨앞(0)의 5번 위치부터
$result = substr($original_str, -2) -> $result = “s.” , 맨뒤에서부터의 인덱스 2 만큼
$result = substr($original_str, 5, 4) -> $result = “hard” , 5번 위치부터 4개
$result = substr($original_str, 5, -8) -> $result = “hard to be in other’s” , 5번 위치부터 뒤에서 8번째 까지

Posted in PHP