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