n
newbie.works.with.QT4 марта 2019 г. 13:07

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

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();

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

Рекомендуем хостинг TIMEWEB
Рекомендуем хостинг TIMEWEB
Стабильный хостинг, на котором располагается социальная сеть EVILEG. Для проектов на Django рекомендуем VDS хостинг.

Вам это нравится? Поделитесь в социальных сетях!

12
Evgenii Legotckoi
  • 5 марта 2019 г. 3:38

Добрый день!

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

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

    n
    • 7 марта 2019 г. 13:37

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

      Evgenii Legotckoi
      • 8 марта 2019 г. 3:37

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

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

      #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
        • 9 марта 2019 г. 7:31

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

          n
          • 9 марта 2019 г. 7:36

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

          #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
            • 9 марта 2019 г. 8:35

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

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

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

            found=content.find('.');
            

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

              Evgenii Legotckoi
              • 10 марта 2019 г. 5:52

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

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

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

                n
                • 10 марта 2019 г. 8:21

                пример прост: я пишу из консоли переменную 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;
                }
                
                  Evgenii Legotckoi
                  • 11 марта 2019 г. 4:30

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

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

                  #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
                    • 11 марта 2019 г. 11:42

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

                      Evgenii Legotckoi
                      • 11 марта 2019 г. 15:47
                      • (ред.)
                      • Ответ был помечен как решение.

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

                      #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
                        • 12 марта 2019 г. 12:57

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

                          Комментарии

                          Только авторизованные пользователи могут публиковать комментарии.
                          Пожалуйста, авторизуйтесь или зарегистрируйтесь
                          OI
                          • Ora Iro
                          • 24 декабря 2024 г. 17:38

                          C++ - Тест 001. Первая программа и типы данных

                          • Результат:40баллов,
                          • Очки рейтинга-8
                          AD

                          C++ - Тест 004. Указатели, Массивы и Циклы

                          • Результат:50баллов,
                          • Очки рейтинга-4
                          m
                          • molni99
                          • 26 октября 2024 г. 11:37

                          C++ - Тест 004. Указатели, Массивы и Циклы

                          • Результат:80баллов,
                          • Очки рейтинга4
                          Последние комментарии
                          ИМ
                          Игорь Максимов22 ноября 2024 г. 22:51
                          Django - Урок 017. Кастомизированная страница авторизации на Django Добрый вечер Евгений! Я сделал себе авторизацию аналогичную вашей, все работает, кроме возврата к предидущей странице. Редеректит всегда на главную, хотя в логах сервера вижу запросы на правильн…
                          Evgenii Legotckoi
                          Evgenii Legotckoi1 ноября 2024 г. 0:37
                          Django - Урок 064. Как написать расширение для Python Markdown Добрый день. Да, можно. Либо через такие же плагины, либо с постобработкой через python библиотеку Beautiful Soup
                          A
                          ALO1ZE19 октября 2024 г. 18:19
                          Читалка fb3-файлов на Qt Creator Подскажите как это запустить? Я не шарю в программировании и кодинге. Скачал и установаил Qt, но куча ошибок выдается и не запустить. А очень надо fb3 переконвертировать в html
                          ИМ
                          Игорь Максимов5 октября 2024 г. 17:51
                          Django - Урок 064. Как написать расширение для Python Markdown Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
                          d
                          dblas55 июля 2024 г. 21:02
                          QML - Урок 016. База данных SQLite и работа с ней в QML Qt Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
                          Сейчас обсуждают на форуме
                          WD
                          Weave Decor28 декабря 2024 г. 14:18
                          Weave & Decor Weave Decor Where passion for textiles meets innovative design. We specialize in manufacturing a diverse range of high-quality bed sheets, from classic to contemporary, using premium fa…
                          n
                          nkly27 декабря 2024 г. 22:41
                          Нужно запретить перемещение только некоторых итемов, остальные перемещать можно. У меня есть Представление QTreeView и древовидная модель QStandardItemModel подключенная к представлению. Итемы в модели QStandardItem. В разных ветках дерева могут быть элементы с одинаковым им…
                          Evgenii Legotckoi
                          Evgenii Legotckoi25 июня 2024 г. 1:11
                          добавить qlineseries в функции Я тут. Работы оень много. Отправил его в бан.
                          t
                          tonypeachey115 ноября 2024 г. 17:04
                          google domain [url=https://google.com/]domain[/url] domain [http://www.example.com link title]
                          NSProject
                          NSProject4 июня 2022 г. 13:49
                          Всё ещё разбираюсь с кешем. В следствии прочтения данной статьи. Я принял для себя решение сделать кеширование свойств менеджера модели LikeDislike. И так как установка evileg_core для меня не была возможна, ибо он писался…

                          Следите за нами в социальных сетях