`
Michaelmatrix
  • 浏览: 210560 次
  • 来自: 北京
文章分类
社区版块
存档分类
最新评论

glib学习笔记5 使用perl正则表达式

 
阅读更多
转载请注明出处,或联系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出来

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics