如何让我的c程序识别“\ n”字符并忽略它们

时间:2015-11-22 02:27:14

标签: c string comparison newline

我正在创建一个程序,假设检查某个输入字符串只包含某种类型的字符(ASCII字符)。我有一串属于ASCII标准的字符,对于输入字符串中的每个字符,我检查(逐个字符)是否存在于ASCII字符串中。如果角色确实存在,我会将它们移动到一个新的字符串,一个输出字符串。如果它们不存在,我会通知用户并退出程序。

但是,我正在创建的输入字符串既可以从命令行创建,也可以从文本文件创建。我的文本文件似乎总是包含几个新行,它们总是以换行符(“\ n” - 字符)结束,它总是使我的程序报告错误,无论是在字符串的末尾还是在中间。< / p>

如何重新排列以下程序的代码,以便识别“\ n”字符?下面是代码的简化,没有显示我如何定义输入字符串以及如何定义带有ASCII字符的字符串。

char inputstring[];
char outputstring[];
char asciicharacters[];
* Here I read a text-file to the inputstring, and the ASCII-characters to the asciicharacters-string *

int k,i=0;

for(i=0;i<strlen(inputstring);i++)
{

    for(k=0;k<strlen(asciicharacters);k++)
    {

        if(inputstring[i] == asciicharacters[k])
        {
            outputstring[i] = inputstring[i];
            break;
        }
        else if(k == strlen(asciicharacters)-1)
        {
            printf("The character: %c, is not ASCII-standard",input[i]);
            exit(1);
        }

    }

}

当我到达“\ n”字符时,如何创建另一个使程序跳过(并接受为ASCII标准)的条件?

1 个答案:

答案 0 :(得分:2)

您可以在最终else if之前添加此else if

else if( inputstring[i] == '\n' )
{
    break;
}