我正在尝试编写一个名为replace的linux命令,它将替换文件中的字符。我希望这样称呼它:
$./replace I XY test.txt
在此示例中,test.txt
包含“这是测试文件”
如何将字符'I'
替换为"XY"
。我试图使用缓冲区,如下面给出的代码,但由于缓冲区和argv的声明不同,它会产生错误。此外,'I'
存储在一个数组元素中,而"XY"
需要两个。是否存在解决方法?
考虑text.txt
示例:
[T][H][I][S][ ][I][S][ ][A][ ][T][E][S][T][ ][F][I][L][E]
在此示例中,第三个索引(包含'I'
)必须替换为"XY"
这是我的代码,它有上述问题:
#define BUFFERSIZE 4096
/*replace i xy data.txt */
int main(int ac, char *av[])
{
int in_fd, out_fd, n_chars, BufElement,j;
char buf[BUFFERSIZE];
in_fd=open(av[3], O_RDWR);
/*Read characters from file to buffer*/
while ( (nread = read(in_fd , buf, BUFFERSIZE)) > 0 )
{
for (BufElement=0;BufElement < nread;BufElement++)
{
for (j=0; j < strlen(av[1]); j++)
{
if (buf[BufElement] == av[1][j])
buf[BufElement] = av[2]; /*ERROR*/
}/*for*/
}/*for*/
}/*while*/
}/*main*/
答案 0 :(得分:1)
buf[BufElement]
是一个字符,av[2]
是一个字符串(具体是字符指针)。你不能像你已经完成的那样将两者等同起来(buf[BufElement] = av[2];
)而且,即使有可能,你也不能简单地在C中轻松地用缓冲区中的2个字节替换1个字节。它将覆盖下一个字符。 / p>
您需要复制文件内容,直到在临时缓冲区中找到匹配项,将替换字符串附加到此临时缓冲区,然后复制文件的其余内容。