方法
since: 2.14
声明 [src]
gchar*
g_regex_replace_eval (
const GRegex* regex,
const gchar* string,
gssize string_len,
gint start_position,
GRegexMatchFlags match_options,
GRegexEvalCallback eval,
gpointer user_data,
GError** error
)
描述 [src]
将正则表达式中的模式替换为对每个匹配项调用 eval
的输出。
对于以任何类型的后视断言(如“\b”)开始的模式,设置 start_position
与仅传递缩短的字符串并设置 G_REGEX_MATCH_NOTBOL
不同。
以下示例使用 g_regex_replace_eval()
一次性替换多个字符串
static gboolean
eval_cb (const GMatchInfo *info,
GString *res,
gpointer data)
{
gchar *match;
gchar *r;
match = g_match_info_fetch (info, 0);
r = g_hash_table_lookup ((GHashTable *)data, match);
g_string_append (res, r);
g_free (match);
return FALSE;
}
...
GRegex *reg;
GHashTable *h;
gchar *res;
h = g_hash_table_new (g_str_hash, g_str_equal);
g_hash_table_insert (h, "1", "ONE");
g_hash_table_insert (h, "2", "TWO");
g_hash_table_insert (h, "3", "THREE");
g_hash_table_insert (h, "4", "FOUR");
reg = g_regex_new ("1|2|3|4", G_REGEX_DEFAULT, G_REGEX_MATCH_DEFAULT, NULL);
res = g_regex_replace_eval (reg, text, -1, 0, 0, eval_cb, h, NULL);
g_hash_table_destroy (h);
...
Available since: 2.14
参数
string
-
类型:一个
gchar
数组要对其执行匹配的字符串。
数组的长度通过 string_len
参数指定。数据由方法的调用者所有。 每个元素都是一个以 NUL 结尾的 UTF-8 字符串。 string_len
-
类型:
gssize
string
的长度,以字节为单位,如果string
是空终止的,则为 -1。 start_position
-
类型:
gint
字符串匹配的起始索引,以字节为单位。
match_options
-
匹配选项。
eval
-
用于调用每个匹配项的函数。
user_data
-
类型:
gpointer
传递给函数的用户数据。
参数可以 NULL
。数据由方法的调用者所有。 error
-
类型:
GError **
恢复性错误的返回位置。
参数可以 NULL
。如果返回位置不是 NULL
,则必须将其初始化为NULL
GError
。如果没有错误,方法将保留初始化为 NULL
的参数。如果出现错误,将参数设置为新分配的 GError
;调用者将占用数据,并负责释放它。