方法

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

类型:GRegexMatchFlags

匹配选项。

eval

类型:GRegexEvalCallback

用于调用每个匹配项的函数。

user_data

类型:gpointer

传递给函数的用户数据。

参数可以 NULL
数据由方法的调用者所有。
error

类型:GError **

恢复性错误的返回位置。

参数可以 NULL
如果返回位置不是 NULL,则必须将其初始化为 NULL GError
如果没有错误,方法将保留初始化为 NULL 的参数。
如果出现错误,将参数设置为新分配的 GError;调用者将占用数据,并负责释放它。

返回值

类型:gchar*

包含替换的新分配的字符串。

方法的调用者对返回的数据负责,并负责释放它。
该值是一个以 NUL 结尾的 UTF-8 字符串。