n
March 4, 2019, 1:07 p.m.

как найти конкретную строку в файле (блокнот)

c++

У меня следуйщая задача:

ввожу слово или код в консоль, программка считывает, находит в блокноте нужную строку записывает две переменные:
(1-я ту строку которую мы нашли благодоря слову или коду и
2-я следуйщая сторка после неё)
вот так вот.

у меня есть только проверка есть ли слово или код:

#include <iostream>
#include <windows.h>
#include <string.h>
#include <fstream>

using namespace std;

int main()
{
    char word[256], line[256], tmp[256];
    char *buf = NULL;
    ifstream file;
    setlocale(0, "");
    cout << "слово для поиска: ";
    cin.get(word, 256, '\n');

    file.open("D:\\TRAN\\Lib6.txt", ios::in);
    if(!file)
          {
          cout<<"нет такого файла!!!!"<<endl;
                       exit(1);
 }
    while (!file.eof())
    {
        file.getline(line, 256, '\n');
        strcpy(tmp, line);
        buf = strtok(tmp, " ");

        if (buf == NULL)
        {
            cout << "Ошибка" << endl;
                       file.close();
                       system("pause");
            exit(1);
          }
        if (strcmp(buf, word) == 0)
        {
            cout << line <<" : найдено совпадение" << endl;

            system("pause");
            exit(0);

        }

    }
    cout << "нет подобных значений" << endl;
    file.close();
    system("pause");
    return 0;
}

и просто вывод текста:

 const int len = 300, strings = 6;
    const char ch = '\n';
    char mass[len][strings];

    ifstream fs("D:\\TRAN\\Lib6.txt", ios::in | ios::binary); 

    if(!fs) return 1; 

    for(int r = 0; r<strings; r++)
    {
        fs.getline(mass[r], len-1,ch); 
        cout << "String " << r+1 << " = "<< mass[r] << endl; 
    }
    fs.close();

а вот найти строку по слову, записать в переменную
эту строку и в другую переменную следуйщую строку не знаю как...
кажется двигаюсь не в том направлении :(
помогите пожалуйста.

We recommend hosting TIMEWEB
We recommend hosting TIMEWEB
Stable hosting, on which the social network EVILEG is located. For projects on Django we recommend VDS hosting.
12

Добрый день!

Вы не пробовали использовать std::string для строк?

Это было бы несколько проще для поиска строк, вот примеры для поиска строк в строке std::string

n

Добрый вечер, спасибо за ссылку. А для работы нужно весь текст из txt записывать? не получается организовать чтение из файла (не знаю как это сделать)

конечно, нужно считывать

Вот например один из вариантов чтения из файла в одну строку

#include <fstream>
#include <string>

int main(int argc, char** argv)
{
  std::ifstream ifs("myfile.txt");
  std::string content((std::istreambuf_iterator<char>(ifs)), (std::istreambuf_iterator<char>()));
  return 0;
}
n

Большое спасибо!!!! Только один вопрос: как записать в переменную всю строку сначала (у меня просто получается только кусок) и как записать следуйщую строку?

n

Вот у меня так получилось:

#include <fstream>
#include <string>
#include <iostream> 

int main(int argc, char** argv)
{
  setlocale(LC_ALL, "Russian");

  std::ifstream ifs("D:\\TRAN\\Lib6.txt");

  std::string content((std::istreambuf_iterator<char>(ifs)), (std::istreambuf_iterator<char>()));
  std::string str2 ("Seven");

  std::size_t found = content.find(str2);
  if (found!=std::string::npos)
    std::cout << "ïåðâàÿ «èãëà» íàéäåíà â: " << found << "                found 1" << '\n';





    found=content.find('.');
  if (found!=std::string::npos)
    std::cout << "Ïåðèîä íàéäåí ïî àäðåñó: " << found<< "                found 4" << '\n';


    content.replace(content.find(str2),str2.length(),"ðàçäåë");
  std::cout << content << '\n';

  return 0;
}
n

Мысли насчёт второй строчки таковы:

 std::string str2 ("\n");

узнать где переход на следуйщую строку и узнать точку

found=content.find('.');

и записать всё что между ними в переменную (только это в мыслях, а как скомпилировать так ошибки одни)

Что это за кракозябры в коде. Как вообще понять, что вы этим хотите сказать?

У себя код скомпилировал, ну в некоторых случаях там есть выход за пределы массива, если не находит тот же самый Seven.

Не совсем понимаю конкретики вашей проблемы. И ещё перепишите код с использованием фигурных скобок у условий. А то мне кажется, что вы просто не совсем понимаете синтаксис языка. Если фигурный скобок у if нет, то в C++ учитывается в качестве тела условия только одна следующая за if строка, и никакие отступы в данном языке программирования роли не играют.

n

пример прост: я пишу из консоли переменную string -Chto chitaesh?

txt:

Privet, kak dela?
horosho.
Chto chitaesh?
knigy.
interesnaia?
net, no mogy dat pochitat.

программа должна выдать: -knigy.

непонимаю как сказать программе - все символы после конца строки и до точки запиши в пременную dva

#include <fstream>
#include <string>
#include <iostream> 

int main(int argc, char** argv)
{ 
   //dva;
  setlocale(LC_ALL, "Russian");

  std::ifstream ifs("D:\\TRAN\\Lib6.txt");

  std::string content((std::istreambuf_iterator<char>(ifs)), (std::istreambuf_iterator<char>()));
  std::string str2 ("Chto chitaesh?");

  std::cout << str2.size() << std::endl;

  std::size_t found = content.find(str2);
  if (found!=std::string::npos){
        std::cout << "конец слова " << found+str2.size() <<  '\n';
  }



  std::string str2 ("'\n'");
  // нужно чтобы поиск был после ((found+str2.size()
  std::cout << str2.size() << std::endl;

  std::size_t found = content.find(str2);
  if (found!=std::string::npos){
        std::cout << "Наша строка " << found+str2.size() <<  '\n';
  }


    found=content.find('.');
  if (found!=std::string::npos){
     std::cout << "Нужно указать чтобы точка искалась после  (found+str2.size()   " << found<<  '\n';
  }
   //и все символы после ((found+str2.size()  и до точки записать в переменную dva


  std::cout << content << '\n';

  return 0;
}

Ну вот так можно написать программу.

Сохранит в вектор все строки, которые оканчиваются на точку. В вашем случае это как раз ответы получаются.

#include <iostream>
#include <string>
#include <fstream>
#include <vector>

bool endsWith(const std::string& s, const std::string& suffix)
{
    return s.rfind(suffix) == (s.size()-suffix.size());
}

int main()
{
    std::ifstream file("D://text.txt");

    std::vector<std::string> answers;

    std::string str;
    while (std::getline(file, str))
    {
        if (endsWith(str, "."))
        {
            answers.push_back(str);
        }
    }

    for (const std::string& answer : answers)
    {
        std::cout << answer << std::endl;
    }

    return 0;
}

n

Добрый вечер. Извините, неправильно написал..... Ну так выводит все строки с точкой, а мне нужно только следуйщую после нашей.

Ну самый такой вариант в лоб, при полном совпадении строки вопроса и учитывая, что следующая строка, которая оканчивается на точку является ответом, можно написать так.

#include <iostream>
#include <string>
#include <fstream>
#include <vector>

bool endsWith(const std::string& s, const std::string& suffix)
{
    return s.rfind(suffix) == (s.size()-suffix.size());
}

int main()
{
    std::ifstream file("/home/dekadent/text.txt");
    std::string questionStr = "Chto chitaesh?";
    std::string str;

    bool found = false;
    while (std::getline(file, str))
    {
        if (str == questionStr)
        {
            while (std::getline(file, str))
            {
                if (endsWith(str, "."))
                {
                    found = true;
                    break;
                }
            }
        }

        if (found)
        {
            break;
        }
    }

    std::cout << str << std::endl;

    return 0;
}

n

Большооооое спасибо!!!!! Не передать как я вам благодарен, спасибо что всегда отзываетесь. Теперь я смогу продолжить работу в QT!!! (пробую писать бота (Я как вы могли догадаться немного не програмист, моя специализация - анимация),
( с Ui разобрался (строка ввода с кнопочкой), а вот с блокнотом была проблема, но благодоря вам это уже в прошлом (в эти строчки будут закидываться не просто слова, а путь к Waw файлу)) Спасибо!!!!

Comments

Only authorized users can post comments.
Please, Log in or Sign up
Donate

Hello, Dear Users of EVILEG!!!

If the site helped you, then support the development of the site financially, please.

You can do it by following ways:

Thank you, Evgenii Legotckoi

p
Feb. 17, 2020, 2:41 p.m.
pstMem

C++ - Тест 003. Условия и циклы

  • Result:85points,
  • Rating points6
z
Feb. 17, 2020, 6:02 a.m.
zet

C++ - Test 006. Enumerations

  • Result:80points,
  • Rating points4
z
Feb. 17, 2020, 5:49 a.m.
zet

C++ - Test 001. The first program and data types

  • Result:80points,
  • Rating points4
Last comments
Feb. 17, 2020, 3:22 a.m.
Evgenij Legotskoj

Добрый день. Это кастомный тег, помещается в файл, который находится в каталоге templatetags myapp/ templatetags/ myapp.py
B
Feb. 16, 2020, 1:36 p.m.
BahaMeirman

Добрый вечер! Монжно по подробней о теге get_companion? ссылка не работает.
Feb. 16, 2020, 9:35 a.m.
Evgenij Legotskoj

Добрый день. На GitHub исходники, можете посмотреть в официальном репозитории
B
Feb. 16, 2020, 9:29 a.m.
BahaMeirman

Здравстсвуйте Евгений, непонятно мне где эти исходники найти?
Now discuss on the forum
IP
Feb. 20, 2020, 1:24 a.m.
Igor' Poroshin

QSqlQuery query("SELECT CONCAT("#", LPAD(HEX(`t`.RGB), 6, 0)) FROM table AS t");query.exec(); while (query.next()) { QColor(query.value(0).toString()); }
IP
Feb. 19, 2020, 11:55 p.m.
Igor' Poroshin

qDebug() << model->lastError().text() - возвращает текст и код ошибки, который возвращает база данных, чаще всего ошибка бывает из-за неправильного SQL запроса qDebug() << mo…
Feb. 19, 2020, 8:55 a.m.
Mihailll

Можно через сервер сделать
V
Feb. 19, 2020, 7:09 a.m.
Vitali

Да, прямо сходу не заработало, а сейчас просто некогда разбираться, да и я уже решил не использовать в этом приложении WebEngine. Ошибка: WebEngineContext used before QtWebEngine::initialize(…
Feb. 19, 2020, 7:01 a.m.
BlinCT

Просто реально не вижу тут каких то проблем в модели, вот вообще ничего. Но она все равно не отображается, то есть ладно бы если данные бы не появлялись а сама таблица была бы. Так и таблиц…
EVILEG
About
Services
© EVILEG 2015-2019
Recommend hosting TIMEWEB