Chinaunix

标题: 请问C语言里面有没有类似模式匹配的函数啊? [打印本页]

作者: smflyer    时间: 2003-05-04 20:21
标题: 请问C语言里面有没有类似模式匹配的函数啊?
现在要用c语言作文件解析,觉得好繁琐啊,有没有好点的模式匹配(以前习惯用perl了)。
    譬如说aa=bb,如何提出后面的bb啊?:(
作者: JohnBull    时间: 2003-05-04 20:29
标题: 请问C语言里面有没有类似模式匹配的函数啊?
man regex
作者: 无双    时间: 2003-05-04 20:32
标题: 请问C语言里面有没有类似模式匹配的函数啊?
标准c库中没有
但是在glibc中有

就是楼上所说的那个
作者: smflyer    时间: 2003-05-04 20:46
标题: 请问C语言里面有没有类似模式匹配的函数啊?
真的有模式匹配啊
我现在还在用fgetc一个一个字符判断获取呢,累的喘不过气了!:(
作者: 无双    时间: 2003-05-04 20:52
标题: 请问C语言里面有没有类似模式匹配的函数啊?
但是只是在unix平台上有
windows下是没有的(也许可能在网上可以找到这个库)
作者: smflyer    时间: 2003-05-04 20:55
标题: 请问C语言里面有没有类似模式匹配的函数啊?
我就是在unix下开发的:)
谢谢大家哦
作者: smflyer    时间: 2003-05-04 21:05
标题: 请问C语言里面有没有类似模式匹配的函数啊?
我查了一下,是不是就是用regexec的函数啊:)
作者: 无双    时间: 2003-05-04 21:13
标题: 请问C语言里面有没有类似模式匹配的函数啊?
应该是regex函数吧
作者: smflyer    时间: 2003-05-04 22:20
标题: 请问C语言里面有没有类似模式匹配的函数啊?
可以帮我看看为什么会有错误吗?
他说rm_so 和rm_eo不是结构体的成员。

/* regex_test.c
* regular expression test in GNU C
*
* tested on redhat6.1
* gcc regex_test.c -o regex_test
*/

#include "stdio.h"
#include <string.h>;
#include <stdlib.h>;
#include <unistd.h>;
#include <sys/types.h>;
#include <regex.h>;

#define SUBSLEN 10
#define EBUFLEN 128 /* error buffer length */
#define BUFLEN 1024 /* matched buffer length */

int
main (int argc, char **argv)
{
FILE *fp;
size_t len; /* store error message length */
regex_t re; /* store compilned regular expression */
regmatch_t subs[SUBSLEN]; /* store matched string position */
char matched[BUFLEN]; /* store matched strings */
char errbuf[EBUFLEN]; /* store error message */
int err, i;

char string[] = "AAAAabaaababAbAbCdCd123123 11(123){12}";
char pattern[] = "(\\([0-9]+\\))(\\{[0-9]+\\}{1})$";

printf ("String : %s\n", string);
printf ("attern: \"%s\"\n", pattern);

/* compile regular expression */
err = regcomp (&re, pattern, REG_EXTENDED);

if (err)
{
len = regerror (err, &re, errbuf, sizeof (errbuf));
fprintf (stderr, "error: regcomp: %s\n", errbuf);
exit (1);
}
printf ("Total has subexpression: %d\n", re.re_nsub);

/* execute pattern match */
err = regexec (&re, string, (size_t)SUBSLEN, subs, 0);

if (err == REG_NOMATCH)
{
fprintf (stderr, "Sorry, no match ...\n";
regfree (&re);
exit (0);
}
else if (err)
{
len = regerror (err, &re, errbuf, sizeof (errbuf));
fprintf (stderr, "error: regexec: %s\n", errbuf);
exit (1);
}

/* if no REG_NOMATCH and no error, then pattern matched */
printf ("\nOK, has matched ...\n\n";
for (i = 0; i <= re.re_nsub; i++)
{
if (i == 0)
{
printf ("begin: %d, end: %d, ", subs.rm_so, subs.rm_eo);
}
else
{
printf ("subexpression %d begin: %d, end: %d, ",
i, subs.rm_so, subs.rm_eo);
}
len = subs.rm_eo - subs.rm_so;
memcpy (matched, string + subs.rm_so, len);
matched[len] = '\0';
printf ("match: %s\n", matched);
}

regfree(&re);
exit(0);
}
作者: smflyer    时间: 2003-05-04 22:51
标题: 请问C语言里面有没有类似模式匹配的函数啊?
没有人帮我吗?:(
无双兄弟呢:)
作者: smflyer    时间: 2003-05-04 22:55
标题: 请问C语言里面有没有类似模式匹配的函数啊?
好像知道啦,是subs的原因,他是一个数组




欢迎光临 Chinaunix (http://bbs.chinaunix.net/) Powered by Discuz! X3.2