查找替换子字符串C

时间:2015-07-30 22:33:14

标签: c string replace find

我正在尝试查找替换但不仅仅是字符串,还有子字符串。因此,我正在处理的程序查找单词“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);
}

1 个答案:

答案 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()完成的。