Chinaunix首页 | 论坛 | 博客
  • 博客访问: 473116
  • 博文数量: 58
  • 博客积分: 6047
  • 博客等级: 准将
  • 技术积分: 838
  • 用 户 组: 普通用户
  • 注册时间: 2008-01-06 21:05
文章分类

全部博文(58)

文章存档

2009年(24)

2008年(34)

我的朋友

分类: LINUX

2008-12-31 00:00:02

转载请注明出处,或联系fanyuanmail@126.com
用过perl,python,shell的人在使用c语言的字符串时都会觉得c语言字符串的处理太麻烦了。很多程序测试题都会考一些字符串匹配的题。
 
glib提供了一套非常好的正则表达式api,程序可以非常简单的使用c语言来做字符串的匹配。
 
比如一个文件 test_regex.txt
11aa222bb33333cccc44444dddddddd
 
要匹配出所有的数字,使用了glib库的程序
[root@localhost glib_test]# ./g_regex
11
222
33333
44444

#include <glib.h>

static void print_uppercase_words(const gchar* string)
{
        GRegex* regex;
        GMatchInfo *match_info;
        GError *error = NULL;
        regex = g_regex_new("[0-9]+", 0 , 0, NULL);
        g_regex_match(regex, string, 0, &match_info);
        while (g_match_info_matches(match_info)) {
                gchar* word = g_match_info_fetch(match_info, 0);
                g_print("%s\n",word);
                g_free(word);
                g_match_info_next(match_info, NULL);
        }
        g_match_info_free(match_info);
        g_regex_unref(regex);
}
int main()
{
        char *buf;
        int length;
        g_file_get_contents("test_regex.txt", &buf, &length,NULL);
        print_uppercase_words(buf);
        return 0;
}

程序使用起来非常简单,3步就可以搞定

1.创建一个GRegex,来定义你的正则表达式,这里定义了只匹配所有数字。

2.使用g_regex_match来匹配内容中符合正则表达式规则的所有内容。

3.因为匹配出来的是一个集合,利用g_match_info_fetch把每一项fetch出来

阅读(2325) | 评论(2) | 转发(0) |
给主人留下些什么吧!~~

chinaunix网友2009-06-05 23:57:22

专注于 glib 的 qq 技术讨论群 : 1959878 欢迎朋友们加入

chinaunix网友2009-01-04 14:33:39

汗,刚知道glib里有正则