Форум программистов, компьютерный форум CyberForum.ru

Функция getline(). Как исключить знаки препинания (символы)? - C++

Восстановить пароль Регистрация
 
Рейтинг: Рейтинг темы: голосов - 12, средняя оценка - 4.75
brkLTL
1 / 1 / 0
Регистрация: 18.07.2012
Сообщений: 8
01.09.2012, 14:18     Функция getline(). Как исключить знаки препинания (символы)? #1
Задача следующая:
  • Из файла source.txt прочесть слово
  • Отправить запрос в БД
  • Получить перевод слова
  • Записать в файл destination.txt
Пример:
Читаются следующие символы: ('abc', пробел, 'bac', пробел, 'cab', символ новой строки, 'dab'). На восьмой итерации читается EOF.
Использую getline(inputFile, sourceWord, ' ');
До слова "символы:" проблем нет, в БД запросы отправлены, переводы слов найдены, в файл записаны (циклом).

Вопросы:
1. Не пойму как обработать слово "символы:": нужно временно убрать двоеточие, получить перевод слова и записать в destination.txt, после него добавить двоеточие.
2. Дальше: getline(inputFile, sourceWord, ' '); и sourceWord = "('abc',"
Запрос в БД должен идти как "abc" (ответ получим как "абв"), а записать в файл нужно как ('абв',

(С отправкой запроса в БД и получением ответа проблем нет)

Как можно это реализовать?

Часть кода:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
    while(!inputFile.eof())
    {
        //get the first word from file
        getline(inputFile, sourceWord, ' ');
        
    
        
        
        // SELECT `sourceWord ` FROM `tes_words` WHERE `sourceWord` LIKE '****'         
        string query1 = "SELECT `sourceWord` FROM `tes_words` WHERE `sourceWord` LIKE '";
        string query2 = "'";
        // add word from file to query
        string query = query1 + sourceWord + query2;
        outputTest << "\nCompleted select query: " << query;
        cout << "\nCompleted select query: " << endl;
        
        char query_char[200];
        strcpy( query_char, query.c_str() );
    
    // run query
        if(mysql_query(conn, query_char))
        {
        fprintf(stderr, "%s \n", mysql_error(conn));
        printf("Press any key to continue...");
        getch();
        exit(1);
      }
        
      res = mysql_use_result(conn); // grab the result 
      
      bool result_from_database = false;
      
        if((row = mysql_fetch_row(res)) != NULL)
        {
            outputFile << row[0] << endl;
            cout << "\nWord writed to output file." << endl;
            result_from_database = true;
        }
        else
        {
            cout << "\nNo result from database" << endl;
            result_from_database = false;
        }
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
alsav22
5282 / 4801 / 442
Регистрация: 04.06.2011
Сообщений: 13,587
01.09.2012, 14:44     Функция getline(). Как исключить знаки препинания (символы)? #2
Если нужно избавляться от ненужных символов, то может посимвольно читать? Или считывать слово в буфер и обрабатывать.
brkLTL
1 / 1 / 0
Регистрация: 18.07.2012
Сообщений: 8
01.09.2012, 14:49  [ТС]     Функция getline(). Как исключить знаки препинания (символы)? #3
Правильный код этот:
Тот был для поиска и добавления в базу, если нет в БД.
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
    // while(!inputFile.eof())
    for(int i = 0; i < 10; i++)
    {
        //get the first word from file
        getline(inputFile, sourceWord, ' ');
        
        // SELECT `destWord` FROM `tes_words` WHERE `sourceWord` LIKE '***'     
        string query1 = "SELECT `destWord` FROM `tes_words` WHERE `sourceWord` LIKE '";
        string query2 = "'";
        // add word from file to query
        string query = query1 + sourceWord + query2;
        outputTest << "\nCompleted select query: " << query;
        cout << "\nCompleted select query: " << endl;
        
        char query_char[200];
        strcpy( query_char, query.c_str() );
    
    // run query
        if(mysql_query(conn, query_char))
        {
        fprintf(stderr, "%s \n", mysql_error(conn));
        printf("Press any key to continue...");
        getch();
        exit(1);
      }
        
      res = mysql_use_result(conn); // grab the result 
      
      bool result_from_database = false;
      
      // results output to file
        if((row = mysql_fetch_row(res)) != NULL)
        {
            outputFile << row[0] << " ";
            cout << "\nWord writed to output file." << endl;
            result_from_database = true;
        }
        else
        {
            cout << "\nNo result from database." << endl;
            outputFile << "missed_word";
            result_from_database = false;
        }
Добавлено через 4 минуты
Цитата Сообщение от alsav22 Посмотреть сообщение
Если нужно избавляться от ненужных символов, то может посимвольно читать?
Значит я знаю пока только эту функцию Недавно начал изучать, и изученное стараюсь применить на практике.
Может это неправильно - практиковать без завершения учебника?
А каким способом/функцией можно реализовать задуманное?
alsav22
5282 / 4801 / 442
Регистрация: 04.06.2011
Сообщений: 13,587
01.09.2012, 16:45     Функция getline(). Как исключить знаки препинания (символы)? #4
Ещё раз, как в файле записи выглядят ? И как считанное должно выглядеть? Не совсем понял.

Добавлено через 23 минуты
Например, такая конструкция будет считывать из файла отдельные слова и сохранять считанное слово в другом массиве без знаков пунктуации:
Код
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
#include <iostream>
#include <fstream>
#include <cstdlib>
#include <cctype> // для ispunct()
using namespace std;
 
int main()
{
  fstream f("1.txt");
  do
  {     
        char buff[30] = "\0"; // массив для считывания слова из файла 
        char rezult[30] = "\0"; // здесь будет слово уже без знаков пунктуации
        f >> buff; // чтение до пробельного символа 
        if (!f) break; // если конец файла
        // перебор символов в buff
        for (int i = 0; i < strlen(buff); i++)
        {
            if (!ispunct((unsigned char)(buff[i]))) rezult[i] = buff[i]; // если символ не знак пунктуации, то в rezult
            cout << rezult[i];
        }
        cout <<endl; // здесь можно использовать считанное и обработанное слово из файла. 
        
  } while (true);
 
  system("pause");
  return 0;
}

Если посимвольно читать, то можно так:
Код
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
#include <iostream>
#include <fstream>
#include <cstdlib>
#include <cctype> // для isalnum()
using namespace std;
 
int main()
{
 fstream f("1.txt");
  
 while (!f.eof()) // чтение до конца файла
 {   
        char buff;      
        int i = 0;
        char rezult[30] = "\0"; // здесь будет слово уже без знаков пунктуации
        
        while (f.get(buff) && (buff != ' ' && buff != '\n')) // посимвольное чтение из файла до пробела или символа новой строки
        {
            if (isalnum((unsigned char)(buff))) // если символ буква или цифра, то в rezult
            {
                rezult[i] = buff;
                cout << rezult[i];
                i++;
            }
        }
        cout << endl; // здесь можно использовать считанное и обработанное слово из файла. 
 } 
 
  system("pause");
  return 0;
}
Yandex
Объявления
01.09.2012, 16:45     Функция getline(). Как исключить знаки препинания (символы)?
Ответ Создать тему
Опции темы

Текущее время: 21:39. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru