Я пытаюсь сделать так, чтобы программа запрашивала у пользователя имя файла, а затем спрашивала, какое слово они хотели бы удалить. Есть ли способ сделать это, не выполняя никаких функций вне main? (Заранее спасибо!) Вот мой код:
ofstream outFile;
string in;
char in2[800];
char fileName = ' ';
while (in != "XXXX") {
cout << "What do you want to name the file? Enter a name or enter XXXX to quit.\n";
cin >> in;
for (int i = 0; i < in.length(); i++)
{
fileName += in[i];
}
outFile.open(in + ".txt");
if (outFile.fail())
{
outFile << "Can't do it.";
}
else
{
cout << "What do you want in it?\n";
cin >> in2;
cin.getline(in2, sizeof(in2));
outFile << in2;
}
outFile.close();
ifstream reader;
string oneLine;
reader.open(in + ".txt");
if (reader.fail())
{
cout << "Could not read file.\n";
return 0;
}
else
{
reader.clear();
reader.seekg(60L, ios::beg);
getline(reader, oneLine);
cout << "Is there something you'd like to remove from " << in << ".txt?\n";
cin >> in2;
ofstream write("tmp.txt");
while (getline(reader, oneLine)) {
if (oneLine != in2)
write << oneLine << endl;
}
reader.close();
write.close();
remove(fileName + ".txt");
rename("tmp.txt", fileName + ".txt");
return 0;
}
return 0;
}
Есть ли причина, по которой вам не нужны функции? Они почти всегда более желательны с точки зрения разделения ответственности и читабельности кода.
Проработайте свой код построчно и поймите, что делает каждый оператор. fileName + = in [i] не делает то, что вы, вероятно, делаете, за исключением этого.
@Hristijan Gjorshevski тоже не умеет делать это со своим файлом << "cant do it"; в этом конкретном блоке кода.





while (in != "XXXX") { cout << "What do you want to name the file? Enter a name or enter XXXX to quit.\n"; ... }
Если вы введете XXXX, цикл не прекратится. Он попытается обработать остальную часть кода.
char fileName = ' '; объявляет одиночный символ. Вам нужен массив символов. А еще лучше объявить его как std::string fileName;
remove(fileName + ".txt"); не компилируется, потому что remove - это функция C. C не поддерживает классы и не знает, что делать с такими классами, как std::string. Вы хотите предоставить C-строку, вы можете сделать это с помощью fileName.c_str(). Ниже приведены несколько предложений:
int main()
{
ofstream outFile;
string fileName;
string text;
for(;;)
{
cout << "What do you want to name the file?\n";
cout << "Enter a name or enter 999 to quit.\n";
cin >> fileName;
if (fileName == "999")
break;
fileName += ".txt";
outFile.open(fileName);
if (outFile.fail())
{
cout << "Can't do it.";
continue;
}
else
{
for(;;)
{
cout << "What do you want in it?\n";
cout << "Enter a name or enter 999 to stop.\n";
cin >> text;
if (text == "999")
break;
outFile << text << endl;
}
}
outFile.close();
ifstream reader;
reader.open(fileName);
if (reader.fail())
{
cout << "Could not read file.\n";
}
else
{
cout << "Is there something you'd like to remove from " << fileName << "?\n";
cin >> text;
string oneLine;
ofstream write("tmp.txt");
while(getline(reader, oneLine))
{
if (oneLine != text)
write << oneLine << endl;
}
reader.close();
write.close();
remove(fileName.c_str());
rename("tmp.txt", fileName.c_str());
break;
}
}
}
Спасибо, Бармак! Это работает именно так, как я хотел.
Извинения. Неправильно прочитал.
in2был массивомchar, а неin.