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 файлу))
                        Спасибо!!!!

                          Комментарии

                          Только авторизованные пользователи могут публиковать комментарии.
                          Пожалуйста, авторизуйтесь или зарегистрируйтесь
                          AD

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

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

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

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

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

                          • Результат:20баллов,
                          • Очки рейтинга-10
                          Последние комментарии
                          i
                          innorwall15 ноября 2024 г. 13:27
                          Релиз утилиты развертывания С++/Qt и QML приложений CQtDeployer v1.4.0 (Binary Box) optionally substituted alkoxy, optionally substituted alkenyloxy, optionally substituted alkynyloxy, optionally substituted aryloxy, OCH, OC H, OC H, OC H, OC H, OC H, OC H, O C CH, OCH CH OH, O…
                          i
                          innorwall15 ноября 2024 г. 8:26
                          Qt/C++ - Урок 031. QCustomPlot - строим график по времени buy generic priligy We can just chat, and we will not lose too much time anyway
                          i
                          innorwall15 ноября 2024 г. 6:03
                          Qt/C++ - Урок 060. Настройка внешнего вида приложения в рантайме I didnt have an issue work colors priligy dapoxetine 60mg revia cost uk August 3, 2022 Reply
                          i
                          innorwall14 ноября 2024 г. 22:42
                          Как Копировать Файлы в Linux If only females relatives with DZ offspring were considered these percentages were 23 order priligy online uk
                          Сейчас обсуждают на форуме
                          i
                          innorwall14 ноября 2024 г. 14:39
                          добавить qlineseries в функции priligy amazon canada 93 GREB1 protein GREB1 AB011147 6
                          i
                          innorwall11 ноября 2024 г. 21:55
                          Всё ещё разбираюсь с кешем. priligy walgreens levitra dulcolax carbs The third ring was found to be made up of ultra relativistic electrons, which are also present in both the outer and inner rings
                          9
                          9Anonim25 октября 2024 г. 19:10
                          Машина тьюринга // Начальное состояние 0 0, ,<,1 // Переход в состояние 1 при пустом символе 0,0,>,0 // Остаемся в состоянии 0, двигаясь вправо при встрече 0 0,1,>…
                          ИМ
                          Игорь Максимов3 октября 2024 г. 14:05
                          Реализация навигации по разделам Спасибо Евгений!

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