> 백엔드 개발 > PHP 튜토리얼 > CLI 모드에서 PHP의 매개변수를 가져오는 방법

CLI 모드에서 PHP의 매개변수를 가져오는 방법

墨辰丷
풀어 주다: 2023-03-27 15:22:01
원래의
2039명이 탐색했습니다.

이 글에서는 참고값이 좋은 php cli 모드에서 매개변수를 얻는 방법을 주로 소개합니다. 아래 편집기를 사용하여 살펴보겠습니다

PHP가 cli 모드에서 매개변수를 수신하는 방법에는 두 가지가 있습니다

1 argv 배열을 사용하세요

2. getopt 메소드를 사용하세요

1. argv 배열을 사용하세요

예: PHP를 실행하고 세 개의 매개변수(type=news, is_hot=1,limit=5)를 전달해야 합니다.

test.php 만들기

<?php
print_r($argv);
?>
로그인 후 복사

명령줄에서

php test.php news 1 5php test.php news 1 5

输出:

Array
(
  [0] => test.php
  [1] => news
  [2] => 1
  [3] => 5
)
로그인 후 복사

可以看到argv[0]为当前执行的php文件名称,而argv[1]~argv[3]则是传递的参数的值

argv[1]等于type的值

argv[2]等于is_hot的值

argv[3]等于limit的值

这样可以根据argv数组来获取传递的参数进行后续的处理操作。

缺点:

使用argv数组,可以按顺序获取传递的参数。但获取后,需要做一个对应处理,上例中需要把argv[1]对应type参数,argv[2]对应is_hot参数,argv[3]对应limit参数。而如果在传递的过程中,参数顺序写错,则会导致程序出错。

例如:

<?php
$param = array();
$param[&#39;type&#39;] = $argv[1];
$param[&#39;is_hot&#39;] = $argv[2];
$param[&#39;limit&#39;] = $argv[3];
print_r($param);
?>
로그인 후 복사

执行

php test.php news 1 5

输出:

Array
(
  [type] => news
  [is_hot] => 1
  [limit] => 5
)
로그인 후 복사

而传递顺序不同,获取到的参数数值会不同,导致后续程序出错

执行

php test.php 1 5 news

输出:

Array
(
  [type] => 1
  [is_hot] => 5
  [limit] => news
)
로그인 후 복사

因此在使用argv数组传递参数时,需要注意参数传递的顺序。

2.使用getopt方法

getopt 从命令行参数列表中获取选项

array getopt ( string $options [, array $longopts ] )

参数:

options

该字符串中的每个字符会被当做选项字符,匹配传入脚本的选项以单个连字符(-)开头。 比如,一个选项字符串 “x” 识别了一个选项 -x。 只允许 a-z、A-Z 和 0-9。

longopts

选项数组。此数组中的每个元素会被作为选项字符串,匹配了以两个连字符(–)传入到脚本的选项。 例如,长选项元素 “opt” 识别了一个选项 –opt。

options 可能包含了以下元素:

单独的字符(不接受值)

后面跟随冒号的字符(此选项需要值)

后面跟随两个冒号的字符(此选项的值可选)

选项的值是字符串后的第一个参数。它不介意值之前是否有空格。

options 和 longopts 的格式几乎是一样的,唯一的不同之处是 longopts 需要是选项的数组(每个元素为一个选项),而 options 需要一个字符串(每个字符是个选项)。

传值的分隔符可以使用空格或=。

可选项的值不接受空格作为分隔符,只能使用=作为分隔符。

返回值

此函数会返回选项/参数对,失败时返回 FALSE。

选项的解析会终止于找到的第一个非选项,之后的任何东西都会被丢弃。

1.使用options实例

a,b,c 为需要值

d 为可选值

e 为不接受值

<?php
$param = getopt(&#39;a:b:c:d::e&#39;);
print_r($param);
?>
로그인 후 복사

执行

php test.php -a 1 -b 2 -c 3 -d=4 -e 5

输出:

Array
(
  [a] => 1
  [b] => 2
  [c] => 3
  [d] => 4
  [e] => 
)
로그인 후 복사

2.使用longopts实例

type,is_hot 为需要值

limit 为可选值

expire 为不接受值

<?php
$longopt = array(
  &#39;type:&#39;,
  &#39;is_hot:&#39;,
  &#39;limit::&#39;,
  &#39;expire&#39;
);
$param = getopt(&#39;&#39;, $longopt);
print_r($param);
?>
로그인 후 복사
로그인 후 복사

执行

php test.php --type news --is_hot 1 --limit=10 --expire=100

输出:

Array
(
  [type] => news
  [is_hot] => 1
  [limit] => 10
  [expire] => 
)
로그인 후 복사

3.找到第一非选项,后面忽略实例

<?php
$longopt = array(
  &#39;type:&#39;,
  &#39;is_hot:&#39;,
  &#39;limit::&#39;,
  &#39;expire&#39;
);
$param = getopt(&#39;&#39;, $longopt);
print_r($param);
?>
로그인 후 복사
로그인 후 복사

执行

php test.php --type news --is_hots 1 --limit=10 --expire=100

출력:

Array
(
  [type] => news
)
로그인 후 복사

argv[0]이 현재 실행되는 PHP 파일의 이름임을 알 수 있습니다. , argv[1]~argv [3] 전달된 매개변수

argv[1]의 값은

argv[2] 유형의 값과 같습니다. is_hot의 값과 같습니다.

argv[3]은

이 방법으로 후속 처리 작업에 대한 argv 배열 매개변수를 기반으로 전송을 얻을 수 있습니다. 🎜🎜🎜🎜단점: 🎜🎜🎜🎜argv 배열을 사용하면 전달된 매개변수를 순서대로 가져올 수 있습니다. 그러나 이를 얻은 후에는 해당 처리를 수행해야 합니다. 위의 예에서 argv[1]은 유형 매개변수에 해당하고, argv[2]는 is_hot 매개변수에 해당하며, argv[3]은 제한 매개변수에 해당해야 합니다. . 그리고 전송 과정에서 매개변수를 잘못된 순서로 쓰면 프로그램 오류가 발생합니다. 🎜🎜예: 🎜🎜🎜rrreee🎜🎜🎜Execute 🎜🎜php test.php news 1 5🎜🎜출력: 🎜🎜🎜rrreee🎜🎜🎜🎜하지만 통과 순서가 다르며, 얻은 매개변수 값이 달라져 후속 프로그램 오류가 발생합니다🎜🎜🎜Execution🎜🎜php test.php 1 5 news🎜🎜출력:🎜🎜🎜rrreee🎜🎜🎜🎜그래서 사용할 때 argv 배열을 사용하여 매개변수를 전달하려면 매개변수가 전달되는 순서에 주의해야 합니다. 🎜🎜🎜🎜🎜2 getopt 메소드 🎜🎜🎜🎜getopt를 사용하여 명령줄 인수 목록에서 옵션을 가져옵니다🎜🎜array getopt ( string $options [, array $longopts ] )🎜🎜🎜매개변수: 🎜🎜🎜🎜🎜🎜options 🎜🎜🎜🎜이 문자열의 각 문자는 수신 스크립트와 일치하는 옵션 문자로 단일 하이픈(-)으로 시작됩니다. 예를 들어 옵션 문자열 "x"는 -x 옵션을 식별합니다. a-z, A-Z 및 0-9만 허용됩니다. 🎜🎜🎜🎜longopts 🎜🎜🎜🎜옵션 배열. 이 배열의 각 요소는 옵션 문자열로 처리되며 두 개의 하이픈(-)이 있는 스크립트에 전달된 옵션과 일치합니다. 예를 들어, 긴 옵션 요소 "opt"는 옵션 -opt를 식별합니다. 🎜🎜🎜options에는 다음 요소가 포함될 수 있습니다. 🎜🎜🎜🎜 단일 문자(값은 허용되지 않음) 🎜🎜 문자 뒤에 콜론(이 옵션에는 값이 필요함) 🎜🎜 다음에 두 개의 콜론 문자(이 옵션의 값은 선택 사항) 🎜🎜옵션의 값은 문자열 다음의 첫 번째 인수입니다. 값 앞에 공백이 있어도 상관 없습니다. 🎜🎜options와 longopts의 형식은 거의 동일합니다. 유일한 차이점은 longopts는 옵션의 배열이어야 하고(각 요소는 옵션임) 옵션에는 문자열이 필요하다는 것입니다(각 문자는 옵션임). 🎜🎜🎜전달된 값의 구분 기호에는 공백이나 =를 사용할 수 있습니다. 🎜🎜🎜🎜선택적 값은 공백을 구분 기호로 사용할 수 없으며 =만 구분 기호로 사용할 수 있습니다. 🎜🎜🎜반환 값🎜🎜이 함수는 옵션/매개변수 쌍을 반환하고 실패 시 FALSE를 반환합니다. 🎜🎜옵션 구문 분석은 옵션이 아닌 첫 번째 발견 시 종료되며, 그 이후의 모든 항목은 삭제됩니다. 🎜🎜🎜1. 옵션 인스턴스 사용 🎜🎜🎜🎜a, b, c는 필수 값입니다. ​🎜🎜d는 선택 값입니다. ​🎜🎜e는 허용되지 않는 값입니다. 🎜🎜🎜rrreee🎜 🎜🎜Execute🎜🎜php test.php -a 1 -b 2 -c 3 -d=4 -e 5🎜🎜출력: 🎜🎜🎜rrreee🎜🎜🎜🎜2. longopts 인스턴스를 사용하세요 🎜🎜🎜🎜type, is_hot은 필수 값입니다. 🎜🎜limit는 선택 값입니다. 🎜🎜expire는 허용되지 않는 값입니다. 🎜🎜🎜rrreee🎜🎜🎜 실행 🎜🎜php test.php --type news --is_hot 1 --limit=10 --expire=100🎜🎜출력: 🎜🎜🎜rrreee🎜🎜🎜🎜 3. 3. 옵션이 아닌 항목을 찾으세요. 다음 예제는 무시하세요🎜🎜🎜🎜🎜rrreee🎜🎜🎜Execution🎜🎜php test.php --type news --is_hots 1 --limit=10 --expire =100🎜🎜 출력: 🎜🎜🎜rrreee🎜🎜🎜is_hots는 옵션 값이 아니기 때문에(is_hot이 정의됨) 여기서부터 매개 변수는 삭제됩니다. 🎜🎜🎜요약: 🎜🎜🎜argv 배열을 사용하여 매개변수를 전달하면 방법이 간단하고 구현하기 쉽습니다. 매개변수의 순서는 틀릴 수 없으며 매개변수를 얻은 후에 해당 처리를 수행해야 합니다. 🎜

getopt 메소드를 사용하면 매개변수 이름을 사용할 수 있으며, 매개변수의 순서는 상대적으로 표준화되어 임의적일 수 있습니다. (권장)

관련 추천:

PHP부동 소수점 계산 비교 및 ​​rounding_php 기본에 대한 부정확한 솔루션

PHP파일 upload_php 기본에 대한 주요 코드 설명

php 간단함 온라인 인원수 세는 방법_php Skill

위 내용은 CLI 모드에서 PHP의 매개변수를 가져오는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿