假如字符串"(lksjdf)",怎么将括号里的字符取出来?C语言写或者用正则表达式
3个回答
展开全部
单独对于你这个字符串,正则可以这么写:
\((.+)\)
或
^\((.+)\)$
或
^\((\w+)\)$
注:如果处理内容有变化,正则也要修改。
C语言的,就不写了,因为没有正则处理效率高。
感兴趣的话,可以去看:
crifan 正则表达式学习心得
(此处不给贴地址,请自己用google搜标题,即可找到帖子地址)
\((.+)\)
或
^\((.+)\)$
或
^\((\w+)\)$
注:如果处理内容有变化,正则也要修改。
C语言的,就不写了,因为没有正则处理效率高。
感兴趣的话,可以去看:
crifan 正则表达式学习心得
(此处不给贴地址,请自己用google搜标题,即可找到帖子地址)
追问
谢谢你的回答,不过我还是不太明白,假如我用C语言中sscanf将括号里的输出来具体怎么写呢?这里有个参考
#include
int main()
{
const char* s = "iios/12DDWDFF@122";
char buf[20];
sscanf( s, "%*[^/]/%[^@]", buf );
printf( "%s\n", buf );
return 0;
}
结果为:12DDWDFF
在这里 *[^/] 怎么解释呢?
追答
1.你这里的是C语言中的sscanf函数
和我写的正则,的确没啥关系。
2.帮你去看了下
此处:
* 表示匹配0或多个字符,但是只是忽略掉,不输出而已,此处,就是从开头往后找,至于到什么位置结束,取决于后面的匹配规则
后面的:
[^/]:表示,非斜杠
其中[xxx]:表示匹配xxx集合内的字符
所以,上面的*星号就匹配到从开始算,到斜杠的位置,即iios
然后后面又跟着一个斜杠,即:
%*[^/]/
匹配到
iios 和 /
但是都不计算在内
接着后面才去根据规则,匹配你要的数据,即:
12DDWDFF
3.sscanf函数的用法,可以通过
方法1:
google搜:
std::scanf, std::fscanf, std::sscanf
找到的第一个,里面就有详尽的语法解释。
方法2:
百度百科中
也有sscanf的详细解释
自己多利用网络,就可以自己搞定问题了。
展开全部
int length;
int length_reav;
char *pos ;
char *pos_reav;
char str = "(lksjdk)";
pos = strstr(str,"(");
length = strlen(pos);
pos_reav = strstr(pos,")");
length_reav = strlen(pos_reav);
pos[length-length_reav] = '\0';
pos ++;
printf("%s",pos);
int length_reav;
char *pos ;
char *pos_reav;
char str = "(lksjdk)";
pos = strstr(str,"(");
length = strlen(pos);
pos_reav = strstr(pos,")");
length_reav = strlen(pos_reav);
pos[length-length_reav] = '\0';
pos ++;
printf("%s",pos);
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
//以下仅供参考
#include<stdio.h>
int main()
{
int i;
char s[] = "(lksjdf)";//要处理的字符串,可自定义
char tmp[20],*p;
for(p = s; *p != '('; p++);//定位到"("
p++;
for(i = 0; *p != ')'; i++)//以")"做结束标记
{
tmp[i] = *p++;
}
tmp[i] = '\0';
puts(tmp);
return 0;
}
随意写的,还没编译,希望能帮到你
#include<stdio.h>
int main()
{
int i;
char s[] = "(lksjdf)";//要处理的字符串,可自定义
char tmp[20],*p;
for(p = s; *p != '('; p++);//定位到"("
p++;
for(i = 0; *p != ')'; i++)//以")"做结束标记
{
tmp[i] = *p++;
}
tmp[i] = '\0';
puts(tmp);
return 0;
}
随意写的,还没编译,希望能帮到你
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询