如何使用C / C ++从字符串路径“/ user / desktop / abc / post /”中找到子字符串?我想检查该路径中是否存在“abc”文件夹。
路径是字符指针char *ptr = "/user/desktop/abc/post/";
答案 0 :(得分:35)
使用std::string
和find
。
std::string str = "/user/desktop/abc/post/";
bool exists = str.find("/abc/") != std::string::npos;
答案 1 :(得分:17)
在C中,使用strstr()
标准库函数:
const char *str = "/user/desktop/abc/post/";
const int exists = strstr(str, "/abc/") != NULL;
注意不要意外地找到太短的子串(这是起始和结束斜杠的用途)。
答案 2 :(得分:9)
使用std::string
find method的示例:
#include <iostream>
#include <string>
int main (){
std::string str ("There are two needles in this haystack with needles.");
std::string str2 ("needle");
size_t found = str.find(str2);
if(found!=std::string::npos){
std::cout << "first 'needle' found at: " << found << '\n';
}
return 0;
}
结果:
first 'needle' found at: 14.
答案 3 :(得分:1)
使用strstr(const char *s , const char *t)
和include<string.h>
您可以编写自己的功能,其行为与strstr
相同,您也可以根据您的要求进行修改
char * str_str(const char *s, const char *t)
{
int i, j, k;
for (i = 0; s[i] != '\0'; i++)
{
for (j=i, k=0; t[k]!='\0' && s[j]==t[k]; j++, k++);
if (k > 0 && t[k] == '\0')
return (&s[i]);
}
return NULL;
}
答案 4 :(得分:1)
正如user1511510所识别的那样,当abc位于文件名的末尾时,会出现异常情况。我们需要查找/abc/
或/abc
后跟字符串终止符'\0'
。一种天真的方法是检查/abc/
或/abc\0
是否为子串:
#include <stdio.h>
#include <string.h>
int main() {
const char *str = "/user/desktop/abc";
const int exists = strstr(str, "/abc/") || strstr(str, "/abc\0");
printf("%d\n",exists);
return 0;
}
但即使abc后面没有空终止符,exists
也是1。这是因为字符串文字"/abc\0"
等同于"/abc"
。更好的方法是测试/abc
是否是子字符串,然后查看此子字符串后面的字符(使用strstr()
返回的指针索引)是/
还是{{ 1}}:
'\0'
这应该适用于所有情况。
答案 5 :(得分:0)
如果你过多地使用数组,那么你应该包括cstring.h
,因为它有太多的功能,包括查找子串。
答案 6 :(得分:-1)
在C ++中
using namespace std;
string my_string {"Hello world"};
string element_to_be_found {"Hello"};
if(my_string.find(element_to_be_found)!=string::npos)
std::cout<<"Element Found"<<std::endl;