Hàm str_contains trong PHP 8 có tác dụng xác định xem một chuỗi có chứa một chuỗi cần tìm hay không. 1. Cú pháp.str_contains($haystack, $needle)
Trong đó: $haystack là string bạn cần search.$needle là string bạn muốn search trong $haystack .
Hàm str_contains sẽ trả về true nếu chuỗi $needle có trong chuỗi $haystack và ngược lại sẽ trả về false nếu chuỗi $needle không có trong chuỗi
$haystack . 2. Ví dụ.VD1: Với chuỗi cần tìm là chuỗi rỗng.
if (str_contains('toidicode.com', '')) {
echo "contains";
}
//Output: contains
Chú ý: Nếu như bạn kiểm tra một chuỗi trống '' có tồn tại trong một chuỗi khác không thì hàm str_contains sẽ luôn luôn trả về true . VD2: Ví dụ với chữ hoa thường. $string = "Toidicode.Com";
if (str_contains($string, 'com')) {
echo "Contains" . PHP_EOL;
} else {
echo "'com' was not found in '$string'" . PHP_EOL;
}
//Output: 'com' was not found in 'Toidicode.Com'
Như vậy: Hàm str_contains có phân biệt hoa thường. Đăng ký nhận tin.Chúng tôi chỉ gửi tối đa 2 lần trên 1 tháng. Tuyên bố không spam
mail! Bài Viết Mới Hàm str_contains trong PHP 8 có tác dụng xác định xem một chuỗi có chứa một chuỗi cần tìm hay không. 1. Cú pháp.str_contains($haystack, $needle)
Trong đó: $haystack là string bạn cần search.$needle là string bạn muốn search trong $haystack .
Hàm str_contains sẽ trả về true nếu chuỗi $needle có trong chuỗi $haystack và ngược lại sẽ trả về false
nếu chuỗi $needle không có trong chuỗi $haystack . 2. Ví dụ.VD1: Với chuỗi cần tìm là chuỗi rỗng.
if (str_contains('toidicode.com', '')) {
echo "contains";
}
//Output: contains
Chú ý: Nếu như bạn kiểm tra một chuỗi trống '' có tồn tại trong một chuỗi khác không thì hàm str_contains sẽ luôn luôn trả về true . VD2: Ví dụ với chữ hoa thường. $string = "Toidicode.Com";
if (str_contains($string, 'com')) {
echo "Contains" . PHP_EOL;
} else {
echo "'com' was not found in '$string'" . PHP_EOL;
}
//Output: 'com' was not found in 'Toidicode.Com'
Như vậy: Hàm str_contains có phân biệt hoa thường. Đăng ký nhận tin.Chúng tôi chỉ gửi
tối đa 2 lần trên 1 tháng. Tuyên bố không spam mail! Bài Viết Mới
answer 6035 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 !== false là có chủ ý; strpos() trả về giá trị bù mà chuỗi kim bắt đầu trong chuỗi haystack hoặc boolean
false nế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_match 1,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 i cuố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ư $search là 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 AND có 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() - không thể tìm kiếm nhiều từ
- 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ơ và 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 '<pre>';
print_r($match_results);
echo '</pre>';
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 '<pre>';
print_r($match_results);
echo '</pre>';
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 '<pre>';
print_r($match_results);
echo '</pre>';
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ừ 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 , strstr và 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_strpos hoặ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 myFunction luô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 : B chọn một trong hai strpos hoặ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 và $b chứa $c , nhưng bạn có thể muốn hàm của bạn cho bạn biết rằng chỉ $a chứa $c . 21 hữu
ích 3 bình luận chia sẻ answer 21 Bạn có thể sử dụng strstr chứ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
() và 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 small hoặc caps nó 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_count kiểm tra nếu kết quả là >0 . Nhưng vì if câ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-insensitive kiểm tra một từ trong đoạn văn thì bạn có thể sử dụng stripos hà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ẻ
|