Hướng dẫn dùng text contains trong PHP

answer

6035

Hướng dẫn dùng text contains trong PHP

Bạn có thể sử dụng strpos()hàm được sử dụng để tìm sự xuất hiện của một chuỗi bên trong chuỗi khác:

$a = 'How are you?';

if (strpos($a, 'are') !== false) {
    echo 'true';
}

Lưu ý rằng việc sử dụng !== falselà có chủ ý; strpos()trả về giá trị bù mà chuỗi kim bắt đầu trong chuỗi haystack hoặc boolean falsenếu không tìm thấy kim. Vì 0 là phần bù hợp lệ và 0 là "falsey", chúng tôi không thể sử dụng các cấu trúc đơn giản hơn như !strpos($a, 'are').

6035 hữu ích 5 bình luận chia sẻ

answer

521

Bạn có thể sử dụng các biểu thức thông thường, sẽ tốt hơn khi kết hợp từ so với strpose như được đề cập bởi những người dùng khác, nó cũng sẽ trả về đúng cho các chuỗi như giá vé, chăm sóc, nhìn chằm chằm, v.v ... Điều này có thể tránh được trong biểu thức thông thường bằng cách sử dụng các ranh giới từ.

Một kết hợp đơn giản cho có thể trông giống như thế này:

$a = 'How are you?';

if (preg_match('/\bare\b/', $a)) {
    echo 'true';
}

Về mặt hiệu suất, strpose nhanh hơn khoảng ba lần và trong tâm trí, khi tôi thực hiện một triệu so sánh cùng một lúc, phải mất preg_match1,5 giây để hoàn thành và để strpose mất 0,5 giây.

Chỉnh sửa: Để tìm kiếm bất kỳ phần nào của chuỗi, không chỉ từng chữ, tôi khuyên bạn nên sử dụng một biểu thức thông thường như

$a = 'How are you?';
$search 'are y';
if(preg_match("/{$search}/i", $a)) {
    echo 'true';
}

Phần icuối của biểu thức chính quy thay đổi biểu thức chính quy thành không phân biệt chữ hoa chữ thường, nếu bạn không muốn điều đó, bạn có thể bỏ nó.

Bây giờ điều này có thể khá rắc rối trong một số trường hợp vì chuỗi $ search không được vệ sinh trong mọi trường hợp, ý tôi là, nó có thể không vượt qua kiểm tra trong một số trường hợp như $searchlà một đầu vào của người dùng, họ có thể thêm một số chuỗi có thể hoạt động giống như một số khác biểu hiện thông thường...

Ngoài ra, đây là một công cụ tuyệt vời để kiểm tra và xem giải thích về các biểu thức chính quy khác nhau Regex101

Để kết hợp cả hai bộ chức năng thành một chức năng đa mục đích duy nhất (bao gồm cả độ nhạy trường hợp có thể lựa chọn), bạn có thể sử dụng một cái gì đó như thế này:

function FindString($needle,$haystack,$i,$word)
{   // $i should be "" or "i" for case insensitive
    if (strtoupper($word)=="W")
    {   // if $word is "W" then word search instead of string in string search.
        if (preg_match("/\b{$needle}\b/{$i}", $haystack)) 
        {
            return true;
        }
    }
    else
    {
        if(preg_match("/{$needle}/{$i}", $haystack)) 
        {
            return true;
        }
    }
    return false;
    // Put quotes around true and false above to return them as strings instead of as bools/ints.
}

521 hữu ích 5 bình luận chia sẻ

answer

225

Đây là một chức năng tiện ích nhỏ hữu ích trong các tình huống như thế này

// returns true if $needle is a substring of $haystack
function contains($needle, $haystack)
{
    return strpos($haystack, $needle) !== false;
}

225 hữu ích 5 bình luận chia sẻ

answer

125

Mặc dù hầu hết các câu trả lời này sẽ cho bạn biết nếu một chuỗi con xuất hiện trong chuỗi của bạn, đó thường không phải là điều bạn muốn nếu bạn đang tìm kiếm một từ cụ thể và không phải là một chuỗi con .

Có gì khác biệt? Chất nền có thể xuất hiện trong các từ khác:

  • "Là" ở đầu "khu vực"
  • "Là" ở cuối "thỏ"
  • "Là" ở giữa "giá vé"

Một cách để giảm thiểu điều này là sử dụng biểu thức chính quy kết hợp với ranh giới từ ( \b):

function containsWord($str, $word)
{
    return !!preg_match('#\\b' . preg_quote($word, '#') . '\\b#i', $str);
}

Phương pháp này không có cùng dương tính giả được ghi nhận ở trên, nhưng nó có một số trường hợp cạnh của chính nó. Ranh giới từ phù hợp trên các ký tự không-word ( \W), mà sẽ được bất cứ điều gì đó không phải là a-z, A-Z, 0-9, hoặc _. Điều đó có nghĩa là các chữ số và dấu gạch dưới sẽ được tính là các ký tự từ và các tình huống như thế này sẽ thất bại:

  • "Là" trong "Bạn đang nghĩ gì?"
  • "Là" trong "lol u dunno wut are4?"

Nếu bạn muốn bất cứ điều gì chính xác hơn điều này, bạn sẽ phải bắt đầu thực hiện phân tích cú pháp tiếng Anh và đó là một con giun khá lớn (và dù sao cũng sử dụng đúng cú pháp, không phải lúc nào cũng được đưa ra).

125 hữu ích 5 bình luận chia sẻ

answer

107

Để xác định xem một chuỗi có chứa một chuỗi khác hay không, bạn có thể sử dụng hàm PHP strpose () .

int strpos ( string $haystack , mixed $needle [, int $offset = 0 ] )

php

$haystack = 'how are you';
$needle = 'are';

if (strpos($haystack,$needle) !== false) {
    echo "$haystack contains $needle";
}

?>

THẬN TRỌNG:

Nếu kim bạn đang tìm kiếm ở đầu đống cỏ khô, nó sẽ trả về vị trí 0, nếu bạn thực hiện một phép ==so sánh sẽ không hoạt động, bạn sẽ cần phải thực hiện===

Một ==dấu hiệu là một so sánh và kiểm tra xem biến / biểu thức / hằng ở bên trái có cùng giá trị với biến / biểu thức / hằng ở bên phải hay không.

Một ===dấu hiệu là một so sánh để xem liệu hai biến / expresions / hằng có bằng nhau ANDcó cùng loại hay không - tức là cả hai đều là chuỗi hoặc cả hai đều là số nguyên.

107 hữu ích 1 bình luận chia sẻ

answer

58

Nhìn vàostrpos() :

php
    $mystring = 'abc';
    $findme   = 'a';
    $pos = strpos($mystring, $findme);

    // Note our use of ===. Simply, == would not work as expected
    // because the position of 'a' was the 0th (first) character.
    if ($pos === false) {
        echo "The string '$findme' was not found in the string '$mystring'.";
    }
    else {
        echo "The string '$findme' was found in the string '$mystring',";
        echo " and exists at position $pos.";
    }
?>

58 hữu ích 0 bình luận chia sẻ

answer

57

Sử dụng strstr()hoặc stristr()nếu tìm kiếm của bạn không phân biệt chữ hoa chữ thường sẽ là một lựa chọn khác.

57 hữu ích 3 bình luận chia sẻ

answer

42

Nhận xét ngang hàng với Samoody và Lego Stormtroopr.

Nếu bạn đang tìm kiếm một thuật toán PHP để xếp hạng kết quả tìm kiếm dựa trên mức độ gần gũi / mức độ liên quan của nhiều từ thì đây là cách nhanh chóng và dễ dàng để tạo kết quả tìm kiếm chỉ với PHP:

Các vấn đề với các phương pháp tìm kiếm boolean khác như strpos(), preg_match(), strstr()hoặcstristr()

  1. không thể tìm kiếm nhiều từ
  2. kết quả là không được xếp hạng

Phương pháp PHP dựa trên Mô hình không gian vectơtf-idf (thuật ngữ tần số tài liệu nghịch đảo tần số):

Nghe có vẻ khó khăn nhưng dễ dàng đáng ngạc nhiên.

Nếu chúng ta muốn tìm kiếm nhiều từ trong một chuỗi, vấn đề cốt lõi là làm thế nào chúng ta gán trọng số cho từng từ đó?

Nếu chúng ta có thể cân nhắc các thuật ngữ trong một chuỗi dựa trên mức độ đại diện của toàn bộ chuỗi, chúng ta có thể sắp xếp các kết quả của mình theo các chuỗi phù hợp nhất với truy vấn.

Đây là ý tưởng của mô hình không gian vectơ, không xa cách hoạt động của tìm kiếm toàn văn bản SQL:

function get_corpus_index($corpus = array(), $separator=' ') {

    $dictionary = array();

    $doc_count = array();

    foreach($corpus as $doc_id => $doc) {

        $terms = explode($separator, $doc);

        $doc_count[$doc_id] = count($terms);

        // tf–idf, short for term frequency–inverse document frequency, 
        // according to wikipedia is a numerical statistic that is intended to reflect 
        // how important a word is to a document in a corpus

        foreach($terms as $term) {

            if(!isset($dictionary[$term])) {

                $dictionary[$term] = array('document_frequency' => 0, 'postings' => array());
            }
            if(!isset($dictionary[$term]['postings'][$doc_id])) {

                $dictionary[$term]['document_frequency']++;

                $dictionary[$term]['postings'][$doc_id] = array('term_frequency' => 0);
            }

            $dictionary[$term]['postings'][$doc_id]['term_frequency']++;
        }

        //from http://phpir.com/simple-search-the-vector-space-model/

    }

    return array('doc_count' => $doc_count, 'dictionary' => $dictionary);
}

function get_similar_documents($query='', $corpus=array(), $separator=' '){

    $similar_documents=array();

    if($query!=''&&!empty($corpus)){

        $words=explode($separator,$query);

        $corpus=get_corpus_index($corpus, $separator);

        $doc_count=count($corpus['doc_count']);

        foreach($words as $word) {

            if(isset($corpus['dictionary'][$word])){

                $entry = $corpus['dictionary'][$word];


                foreach($entry['postings'] as $doc_id => $posting) {

                    //get term frequency–inverse document frequency
                    $score=$posting['term_frequency'] * log($doc_count + 1 / $entry['document_frequency'] + 1, 2);

                    if(isset($similar_documents[$doc_id])){

                        $similar_documents[$doc_id]+=$score;

                    }
                    else{

                        $similar_documents[$doc_id]=$score;

                    }
                }
            }
        }

        // length normalise
        foreach($similar_documents as $doc_id => $score) {

            $similar_documents[$doc_id] = $score/$corpus['doc_count'][$doc_id];

        }

        // sort from  high to low

        arsort($similar_documents);

    }   

    return $similar_documents;
}

TRƯỜNG HỢP 1

$query = 'are';

$corpus = array(
    1 => 'How are you?',
);

$match_results=get_similar_documents($query,$corpus);
echo '
';
    print_r($match_results);
echo '
'
;

KẾT QUẢ

Array
(
    [1] => 0.52832083357372
)

TRƯỜNG HỢP 2

$query = 'are';

$corpus = array(
    1 => 'how are you today?',
    2 => 'how do you do',
    3 => 'here you are! how are you? Are we done yet?'
);

$match_results=get_similar_documents($query,$corpus);
echo '
';
    print_r($match_results);
echo '
'
;

CÁC KẾT QUẢ

Array
(
    [1] => 0.54248125036058
    [3] => 0.21699250014423
)

TRƯỜNG HỢP 3

$query = 'we are done';

$corpus = array(
    1 => 'how are you today?',
    2 => 'how do you do',
    3 => 'here you are! how are you? Are we done yet?'
);

$match_results=get_similar_documents($query,$corpus);
echo '
';
    print_r($match_results);
echo '
'
;

CÁC KẾT QUẢ

Array
(
    [3] => 0.6813781191217
    [1] => 0.54248125036058
)

Có rất nhiều cải tiến được thực hiện nhưng các mô hình cung cấp một cách để nhận được kết quả tốt từ các truy vấn tự nhiên, mà không có các toán tử logic như strpos(), preg_match(), strstr()hoặc stristr().

LỢI ÍCH

Tùy chọn loại bỏ sự dư thừa trước khi tìm kiếm các từ

  • do đó giảm kích thước chỉ mục và dẫn đến yêu cầu lưu trữ ít hơn

  • ít đĩa I / O

  • lập chỉ mục nhanh hơn và do đó tìm kiếm nhanh hơn.

1. Bình thường hóa

  • Chuyển đổi tất cả văn bản sang chữ thường

2. Loại bỏ mật khẩu

  • Loại bỏ các từ khỏi văn bản không có nghĩa thực sự (như 'và', 'hoặc', 'the', 'cho', v.v.)

3. Thay thế từ điển

  • Thay thế các từ bằng những từ khác có nghĩa giống hệt hoặc tương tự. (ví dụ: thay thế các trường hợp 'đói' và 'đói' bằng 'đói')

  • Các biện pháp thuật toán tiếp theo (snowball) có thể được thực hiện để tiếp tục giảm các từ theo nghĩa thiết yếu của chúng.

  • Việc thay thế tên màu bằng các số thập lục phân của chúng

  • Việc giảm các giá trị số bằng cách giảm độ chính xác là những cách khác để chuẩn hóa văn bản.

TÀI NGUYÊN

  • http://linuxgazette.net/164/sephton.html
  • http://snowball.tartarus.org/
  • Giải thích về Điểm số Tìm kiếm Fulltext của MySQL
  • http://dev.mysql.com/doc/iternals/en/full-text-search.html
  • http://en.wikipedia.org/wiki/Vector_space_model
  • http://en.wikipedia.org/wiki/Tf%E2%80%93idf
  • http://phpir.com/simple-search-the-vector-space-model/

42 hữu ích 0 bình luận chia sẻ

answer

41

Sử dụng kết hợp không phân biệt chữ hoa chữ thường bằng cách sử dụng stripos():

if (stripos($string,$stringToSearch) !== false) {
    echo 'true';
}

41 hữu ích 0 bình luận chia sẻ

answer

40

Nếu bạn muốn tránh vấn đề "chim ưng" và "sự thật", bạn có thể sử dụng lớp nền:

if (substr_count($a, 'are') > 0) {
    echo "at least one 'are' is present!";
}

Nó chậm hơn một chút so với strpose nhưng nó tránh được các vấn đề so sánh.

40 hữu ích 0 bình luận chia sẻ

answer

31

Một tùy chọn khác là sử dụng hàm strstr () . Cái gì đó như:

if (strlen(strstr($haystack,$needle))>0) {
// Needle Found
}

Điểm cần lưu ý: Hàm strstr () phân biệt chữ hoa chữ thường. Đối với tìm kiếm không phân biệt chữ hoa chữ thường, hãy sử dụng hàm stristr () .

31 hữu ích 2 bình luận chia sẻ

answer

28

Tôi là một chút ấn tượng rằng không ai trong số các câu trả lời ở đây là sử dụng strpos, strstrvà các chức năng tương tự như đề cập chức năng nhiều byte Chuỗi chưa (2015/05/08).

Về cơ bản, nếu bạn gặp khó khăn khi tìm từ có ký tự cụ thể cho một số ngôn ngữ , chẳng hạn như tiếng Đức, tiếng Pháp, tiếng Bồ Đào Nha, tiếng Tây Ban Nha, v.v. (ví dụ: ä , é , ô , ç , º , ñ ), bạn có thể muốn đi trước Các chức năng với mb_. Do đó, câu trả lời được chấp nhận sẽ sử dụng mb_strposhoặc mb_stripos(đối với trường hợp khớp không phân biệt chữ hoa chữ thường):

if (mb_strpos($a,'are') !== false) {
    echo 'true';
}

Nếu bạn không thể đảm bảo rằng tất cả dữ liệu của bạn là 100% trong UTF-8 , bạn có thể muốn sử dụng các mb_chức năng.

Một bài báo tốt để hiểu tại sao Các nhà phát triển phần mềm Absolute tối thiểu Mỗi Tuyệt đối, tích cực Phải Biết Về Unicode và tự Sets (Không Lý Do!) Bởi Joel Spolsky .

28 hữu ích 0 bình luận chia sẻ

answer

27

if (preg_match('/(are)/', $a)) {
   echo 'true';
}

27 hữu ích 2 bình luận chia sẻ

answer

23

Chức năng dưới đây cũng hoạt động và không phụ thuộc vào bất kỳ chức năng nào khác; nó chỉ sử dụng thao tác chuỗi PHP gốc. Cá nhân, tôi không khuyên bạn điều này, nhưng bạn có thể thấy nó hoạt động như thế nào:

php

if (!function_exists('is_str_contain')) {
  function is_str_contain($string, $keyword)
  {
    if (empty($string) || empty($keyword)) return false;
    $keyword_first_char = $keyword[0];
    $keyword_length = strlen($keyword);
    $string_length = strlen($string);

    // case 1
    if ($string_length < $keyword_length) return false;

    // case 2
    if ($string_length == $keyword_length) {
      if ($string == $keyword) return true;
      else return false;
    }

    // case 3
    if ($keyword_length == 1) {
      for ($i = 0; $i < $string_length; $i++) {

        // Check if keyword's first char == string's first char
        if ($keyword_first_char == $string[$i]) {
          return true;
        }
      }
    }

    // case 4
    if ($keyword_length > 1) {
      for ($i = 0; $i < $string_length; $i++) {
        /*
        the remaining part of the string is equal or greater than the keyword
        */
        if (($string_length + 1 - $i) >= $keyword_length) {

          // Check if keyword's first char == string's first char
          if ($keyword_first_char == $string[$i]) {
            $match = 1;
            for ($j = 1; $j < $keyword_length; $j++) {
              if (($i + $j < $string_length) && $keyword[$j] == $string[$i + $j]) {
                $match++;
              }
              else {
                return false;
              }
            }

            if ($match == $keyword_length) {
              return true;
            }

            // end if first match found
          }

          // end if remaining part
        }
        else {
          return false;
        }

        // end for loop
      }

      // end case4
    }

    return false;
  }
}

Kiểm tra:

var_dump(is_str_contain("test", "t")); //true
var_dump(is_str_contain("test", "")); //false
var_dump(is_str_contain("test", "test")); //true
var_dump(is_str_contain("test", "testa")); //flase
var_dump(is_str_contain("a----z", "a")); //true
var_dump(is_str_contain("a----z", "z")); //true 
var_dump(is_str_contain("mystringss", "strings")); //true 

23 hữu ích 4 bình luận chia sẻ

answer

22

Trong PHP, cách tốt nhất để xác minh xem một chuỗi có chứa một chuỗi con nhất định hay không, là sử dụng hàm trợ giúp đơn giản như thế này:

function contains($haystack, $needle, $caseSensitive = false) {
    return $caseSensitive ?
            (strpos($haystack, $needle) === FALSE ? FALSE : TRUE):
            (stripos($haystack, $needle) === FALSE ? FALSE : TRUE);
}

Giải trình:

  • strpos tìm vị trí xuất hiện đầu tiên của chuỗi con phân biệt chữ hoa chữ thường trong chuỗi.
  • stripos tìm vị trí xuất hiện đầu tiên của chuỗi con không phân biệt chữ hoa chữ thường trong chuỗi.
  • myFunction($haystack, $needle) === FALSE ? FALSE : TRUEđảm bảo myFunctionluôn trả về giá trị boolean và sửa hành vi không mong muốn khi chỉ số của chuỗi con là 0.
  • $caseSensitive ? A : Bchọn một trong hai strposhoặc striposđể thực hiện công việc, tùy thuộc vào giá trị của $caseSensitive.

Đầu ra:

var_dump(contains('bare','are'));            // Outputs: bool(true)
var_dump(contains('stare', 'are'));          // Outputs: bool(true)
var_dump(contains('stare', 'Are'));          // Outputs: bool(true)
var_dump(contains('stare', 'Are', true));    // Outputs: bool(false)
var_dump(contains('hair', 'are'));           // Outputs: bool(false)
var_dump(contains('aren\'t', 'are'));        // Outputs: bool(true)
var_dump(contains('Aren\'t', 'are'));        // Outputs: bool(true)
var_dump(contains('Aren\'t', 'are', true));  // Outputs: bool(false)
var_dump(contains('aren\'t', 'Are'));        // Outputs: bool(true)
var_dump(contains('aren\'t', 'Are', true));  // Outputs: bool(false)
var_dump(contains('broad', 'are'));          // Outputs: bool(false)
var_dump(contains('border', 'are'));         // Outputs: bool(false)

22 hữu ích 1 bình luận chia sẻ

answer

21

Tôi đã có một số rắc rối với điều này, và cuối cùng tôi đã chọn để tạo ra giải pháp của riêng tôi. Không sử dụng công cụ biểu thức chính quy :

function contains($text, $word)
{
    $found = false;
    $spaceArray = explode(' ', $text);

    $nonBreakingSpaceArray = explode(chr(160), $text);

    if (in_array($word, $spaceArray) ||
        in_array($word, $nonBreakingSpaceArray)
       ) {

        $found = true;
    }
    return $found;
 }

Bạn có thể nhận thấy rằng các giải pháp trước đây không phải là câu trả lời cho từ đang được sử dụng làm tiền tố cho từ khác. Để sử dụng ví dụ của bạn:

$a = 'How are you?';
$b = "a skirt that flares from the waist";
$c = "are";

Với các mẫu ở trên, cả $a$bchứa $c, nhưng bạn có thể muốn hàm của bạn cho bạn biết rằng chỉ $achứa $c.

21 hữu ích 3 bình luận chia sẻ

answer

21

Bạn có thể sử dụng strstrchức năng:

$haystack = "I know programming";
$needle   = "know";
$flag = strstr($haystack, $needle);

if ($flag){

    echo "true";
}

Không sử dụng chức năng sẵn có:

$haystack  = "hello world";
$needle = "llo";

$i = $j = 0;

while (isset($needle[$i])) {
    while (isset($haystack[$j]) && ($needle[$i] != $haystack[$j])) {
        $j++;
        $i = 0;
    }
    if (!isset($haystack[$j])) {
        break;
    }
    $i++;
    $j++;

}
if (!isset($needle[$i])) {
    echo "YES";
}
else{
    echo "NO ";
}

21 hữu ích 1 bình luận chia sẻ

answer

16

Một tùy chọn khác để tìm sự xuất hiện của một từ trong chuỗi bằng strstr ()stristr () giống như sau:

php
    $a = 'How are you?';
    if (strstr($a,'are'))  // Case sensitive
        echo 'true';
    if (stristr($a,'are'))  // Case insensitive
        echo 'true';
?>

16 hữu ích 1 bình luận chia sẻ

answer

14

Nó có thể được thực hiện theo ba cách khác nhau:

 $a = 'How are you?';

1- stristr ()

 if (strlen(stristr($a,"are"))>0) {
    echo "true"; // are Found
 } 

2- strpose ()

 if (strpos($a, "are") !== false) {
   echo "true"; // are Found
 }

3- preg_match ()

 if( preg_match("are",$a) === 1) {
   echo "true"; // are Found
 }

14 hữu ích 1 bình luận chia sẻ

answer

14

Phiên bản tay ngắn

$result = false!==strpos($a, 'are');

14 hữu ích 1 bình luận chia sẻ

answer

14

Để tìm một "từ", thay vì sự xuất hiện của một loạt các chữ cái trong thực tế có thể là một phần của một từ khác, sau đây sẽ là một giải pháp tốt.

$string = 'How are you?';
$array = explode(" ", $string);

if (in_array('are', $array) ) {
    echo 'Found the word';
}

14 hữu ích 1 bình luận chia sẻ

answer

13

Bạn nên sử dụng định dạng Không phân biệt chữ hoa chữ thường, vì vậy nếu giá trị được nhập nằm trong smallhoặc capsnó không quan trọng.

php
$grass = "This is pratik joshi";
$needle = "pratik";
if (stripos($grass,$needle) !== false) { 

 /*If i EXCLUDE : !== false then if string is found at 0th location, 
   still it will say STRING NOT FOUND as it will return '0' and it      
   will goto else and will say NOT Found though it is found at 0th location.*/
    echo 'Contains word';
}else{
    echo "does NOT contain word";
}
?>

Ở đây, các sọc tìm thấy kim trong heystack mà không cần xem xét trường hợp (nhỏ / mũ).

Mẫu PHPCode có đầu ra

13 hữu ích 1 bình luận chia sẻ

answer

13

Rất nhiều câu trả lời sử dụng substr_countkiểm tra nếu kết quả là >0. Nhưng vì ifcâu lệnh coi zero giống như false , bạn có thể tránh kiểm tra đó và viết trực tiếp:

if (substr_count($a, 'are')) {

Để kiểm tra nếu không có, thêm !toán tử:

if (!substr_count($a, 'are')) {

13 hữu ích 1 bình luận chia sẻ

answer

12

Có lẽ bạn có thể sử dụng một cái gì đó như thế này:

php
    findWord('Test all OK');

    function findWord($text) {
        if (strstr($text, 'ok')) {
            echo 'Found a word';
        }
        else
        {
            echo 'Did not find a word';
        }
    }
?>

12 hữu ích 0 bình luận chia sẻ

answer

11

Không sử dụng preg_match()nếu bạn chỉ muốn kiểm tra nếu một chuỗi được chứa trong một chuỗi khác. Sử dụng strpos()hoặc strstr()thay vào đó vì chúng sẽ nhanh hơn. ( http://in2.php.net/preg_match )

if (strpos($text, 'string_name') !== false){
   echo 'get the string';
}

11 hữu ích 0 bình luận chia sẻ

answer

10

Nếu bạn muốn kiểm tra xem chuỗi có chứa một số từ cụ thể không, bạn có thể thực hiện:

$badWords = array("dette", "capitale", "rembourser", "ivoire", "mandat");

$string = "a string with the word ivoire";

$matchFound = preg_match_all("/\b(" . implode($badWords,"|") . ")\b/i", $string, $matches);

if ($matchFound) {
    echo "a bad word has been found";
}
else {
    echo "your string is okay";
}

Điều này rất hữu ích để tránh thư rác khi gửi email chẳng hạn.

10 hữu ích 0 bình luận chia sẻ

answer

9

Bạn cần sử dụng các toán tử giống hệt / không giống nhau vì strpose có thể trả về 0 làm giá trị chỉ mục. Nếu bạn thích các toán tử ternary, hãy cân nhắc sử dụng các thao tác sau (có vẻ hơi ngược tôi sẽ thừa nhận):

echo FALSE === strpos($a,'are') ? 'false': 'true';

9 hữu ích 0 bình luận chia sẻ

answer

9

Hàm strpose hoạt động tốt, nhưng nếu bạn muốn case-insensitivekiểm tra một từ trong đoạn văn thì bạn có thể sử dụng striposhàm của PHP.

Ví dụ,

$result = stripos("I love PHP, I love PHP too!", "php");
if ($result === false) {
    // Word does not exist
}
else {
    // Word exists
}

Tìm vị trí xuất hiện đầu tiên của chuỗi con không phân biệt chữ hoa chữ thường trong chuỗi.

Nếu từ không tồn tại trong chuỗi thì nó sẽ trả về false nếu không nó sẽ trả về vị trí của từ.

9 hữu ích 0 bình luận chia sẻ

answer

8

Kiểm tra xem chuỗi có chứa từ cụ thể không?

Điều này có nghĩa là chuỗi phải được giải quyết thành các từ (xem ghi chú bên dưới).

Một cách để làm điều này và chỉ định các dấu phân cách là sử dụng preg_split( doc ):

php

function contains_word($str, $word) {
  // split string into words
  // separators are substrings of at least one non-word character
  $arr = preg_split('/\W+/', $str, NULL, PREG_SPLIT_NO_EMPTY);

  // now the words can be examined each
  foreach ($arr as $value) {
    if ($value === $word) {
      return true;
    }
  }
  return false;
}

function test($str, $word) {
  if (contains_word($str, $word)) {
    echo "string '" . $str . "' contains word '" . $word . "'\n";
  } else {
    echo "string '" . $str . "' does not contain word '" . $word . "'\n" ;
  }
}

$a = 'How are you?';

test($a, 'are');
test($a, 'ar');
test($a, 'hare');

?>

Chạy cho

$ php -f test.php                   
string 'How are you?' contains word 'are' 
string 'How are you?' does not contain word 'ar'
string 'How are you?' does not contain word 'hare'

Lưu ý: Ở đây chúng tôi không có nghĩa là từ cho mỗi chuỗi ký hiệu.

Một định nghĩa thực tế của từ theo nghĩa là công cụ biểu thức chính quy PCRE, trong đó các từ là các từ chỉ bao gồm các ký tự từ, được phân tách bằng các ký tự không phải từ.

Ký tự "từ" là bất kỳ chữ cái hoặc chữ số hoặc ký tự gạch dưới, nghĩa là, bất kỳ ký tự nào có thể là một phần của "từ" Perl. Định nghĩa của các chữ cái và chữ số được điều khiển bởi các bảng ký tự của PCRE và có thể thay đổi nếu diễn ra kết hợp cụ thể theo địa phương (..)

8 hữu ích 0 bình luận chia sẻ

answer

7

Một chuỗi có thể được kiểm tra với chức năng dưới đây:

function either_String_existor_not($str, $character) {
    if (strpos($str, $character) !== false) {
        return true;
    }
    return false;
}

7 hữu ích 2 bình luận chia sẻ