>백엔드 개발 >PHP 튜토리얼 >정규식을 사용하여 PHP의 텍스트에서 URL을 어떻게 추출할 수 있습니까?

정규식을 사용하여 PHP의 텍스트에서 URL을 어떻게 추출할 수 있습니까?

Linda Hamilton
Linda Hamilton원래의
2024-12-20 21:04:14474검색

How Can I Extract URLs from Text in PHP Using Regular Expressions?

정규 표현식을 사용하여 PHP의 텍스트에서 URL 추출

PHP 프로그래밍의 맥락에서 텍스트에서 URL을 추출하는 방법은 다음과 같습니다. 특히 preg_match() 함수를 사용하는 정규 표현식입니다. 자세한 설명은 다음과 같습니다.

preg_match()와 함께 정규식 사용

preg_match() 함수는 두 개의 매개변수를 사용합니다:

  • 패턴: text.
  • String: 검색할 텍스트.

이 경우 URL과 일치하는 정규식을 구성해야 합니다. 패턴 예는 다음과 같습니다.

#\bhttps?://[^\s()<>]+(?:([\w\d]+)|([^[:punct:]\s]|/))#

이 패턴은 다음 형식의 URL을 캡처합니다.

  • "http" 또는 "https" 프로토콜로 시작합니다.
  • 도메인 이름 또는 IP 주소와 일치합니다.
  • 선택적 포트 번호 또는 path.

정규식 적용

제공된 텍스트에서 URL을 추출하려면 다음 코드를 사용하세요.

preg_match_all('#\bhttps?://[^\s()<>]+(?:([\w\d]+)|([^[:punct:]\s]|/))#', $string, $match);

여기서 $string에는 검색할 텍스트가 포함되어 있습니다.

캡처된 파일에 액세스 URL

정규식 일치 결과는 $match 배열에 저장됩니다. URL은 다음과 같이 액세스할 수 있는 첫 번째 그룹에서 캡처됩니다.

$url = $match[1][0];

이 정규 표현식에는 특정 잘못된 형식의 URL을 처리하는 데 여전히 제한이 있습니다. 보다 복잡한 시나리오의 경우 WordPress의 wp-includes/formatting.php 기능을 사용하는 등의 대체 접근 방식이 필요할 수 있습니다.

위 내용은 정규식을 사용하여 PHP의 텍스트에서 URL을 어떻게 추출할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.