我正在尝试查找替换但不仅仅是字符串,还有子字符串。因此,我正在处理的程序查找单词“bar”并在“bar”的任何实例前面附加“foo”。所以我的方法是,不是实际附加字符串,而是用“foobar”替换整个字符串“bar”。我现在的代码(未完全测试)应该找到并替换所有出现的“bar”和“foobar”。但是,如果有一个看起来像“bar123abc”的字符串,它不会用“foobar123abc”替换它。
这是我的代码:
static void replaceAllString(char *buf, const char *orig, const char *replace)
{
int olen, rlen;
char *s, *d;
char *tmpbuf;
if (!buf || !*buf || !orig || !*orig || !replace)
return;
tmpbuf = malloc(strlen(buf) + 1);
if (tmpbuf == NULL)
return;
olen = strlen(orig);
rlen = strlen(replace);
s = buf;
d = tmpbuf;
while (*s) {
if (strncmp(s, orig, olen) == 0) {
strcpy(d, replace);
s += olen;
d += rlen;
}
else
*d++ = *s++;
}
*d = '\0';
strcpy(buf, tmpbuf);
free(tmpbuf);
}
答案 0 :(得分:1)
我可以这样做:
static char *replaceAll(char *buf, int buflen, const char *orig, const char *replace) {
if (!buf || !*buf || !orig || !*orig || !replace) return buf;
int olen = strlen(orig), rlen = strlen(replace);
int max = strlen(buf) + 1;
if (olen < rlen) {
max = rlen * ((max / olen) + 1) + 1;
}
char *tmpbuf = malloc(max);
char *bp = buf, *tp = tmpbuf, *sp;
while (NULL != (sp = strstr(bp, orig))) {
int f = sp - bp;
memmove(tp, bp, f);
memmove(tp + f, replace, rlen);
tp += f + rlen;
bp += f + olen; // no recursive replacement
}
strcpy(tp, bp);
strncpy(buf, tmpbuf, buflen);
free(tmpbuf);
return buf;
}
char haystack[128] = "123bar456bar7ba8ar9bar0";
int main(int ac, char *av[]) {
printf("%s\n", replaceAll(haystack, sizeof haystack, "bar", "foobar"));
}
注意:传递buflen
不是可选的!你不要写入你不知道长度的内存缓冲区。如果我正在采访C程序员,这将是一个即时“没有雇用”。 tmpbuf
的长度为max
,粗略计算最坏情况(类似“barbarbar”)。这里的繁重工作是由strstr()
完成的。