С Новым годом! Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/13: Рейтинг темы: голосов - 13, средняя оценка - 5.00
0 / 0 / 0
Регистрация: 04.03.2015
Сообщений: 55

Подстрока, заключенная в кавычки

14.04.2015, 11:57. Показов 3008. Ответов 12
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Всем добрый день!

Вот такая примерно задачка.

Имеется string S1="This is the long string having some words \"in quotes\"";
Надо то, что заключено в кавычки (в данном случае - "in quotes") положить в string S2.
Или, скажем, сложить такие квотированные подстроки в вектор vector<string>.

Спасибо за помощь.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
14.04.2015, 11:57
Ответы с готовыми решениями:

Если в БД встречается запись заключенная в кавычки, как изменить SQL запрос:
Например: ООО &quot;Рога и копыта&quot;. Добавить квадратные скобки? SELECT * FROM MyTable WHERE (Organization Like &quot;%' + Edit1.Text +...

Дана строка, содержащая кавычки. Выдать сообщение правильно ли расставлены кавычки
Дана строка, содержащая кавычки. Выдать сообщение правильно ли расставлены кавычки (количество открывающихся соответствует количеству...

В заданной строке содержатся двойные кавычки. Напечатать все слова, взятые в кавычки
в заданной строке содержатся двойные кавычки. Напечатать все слова, взятые в кавычки.

12
7804 / 6568 / 2988
Регистрация: 14.04.2014
Сообщений: 28,705
14.04.2015, 12:00
regex используй.
1
0 / 0 / 0
Регистрация: 04.03.2015
Сообщений: 55
14.04.2015, 12:24  [ТС]
Цитата Сообщение от nmcf Посмотреть сообщение
regex используй
Где почитать про использование regex? Я в этом почти не бум-бум...
0
lss
941 / 869 / 355
Регистрация: 10.10.2012
Сообщений: 2,706
14.04.2015, 12:47
Цитата Сообщение от rotciv Посмотреть сообщение
Я в этом почти не бум-бум...
Если не бум-бум, то вот это почитай: http://www.cplusplus.com/refer... ng/substr/
А так же это: http://www.cplusplus.com/refer... ring/find/
1
Почетный модератор
Эксперт С++
 Аватар для SatanaXIII
5851 / 2862 / 392
Регистрация: 01.11.2011
Сообщений: 6,906
14.04.2015, 13:23
rotciv, врукопашную пройтись циклом по строке и скопировать символы меж ковычек во вторую строку.

P.S. Регулярные выражения (вики)
1
0 / 0 / 0
Регистрация: 04.03.2015
Сообщений: 55
14.04.2015, 13:43  [ТС]
Покритикуйте плз. Может быть, как-то поэлегантнее можно?

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
#include <iostream>
 
using namespace std;
 
int main (void){
 
 string S="Hi. \"This string has some quoted words\" and some trail";
 
 string temp, FL="\n========================\n";
 
 cout<<"Original string:"<<FL<<S<<FL<<"Developed string:"<<FL;
 
  size_t pos = S.find("\"");    //  1st "
  string S2 = S.substr (pos+1); // get from " to the end
  size_t len = S2.find("\"");   //  2nd "
  string S3=S2.substr (0, len);
  cout<<S3;
  cout<<"\n========================\n";
  return 0;
}
0
Форумчанин
Эксперт CЭксперт С++
 Аватар для MrGluck
8216 / 5047 / 1437
Регистрация: 29.11.2010
Сообщений: 13,453
14.04.2015, 14:11
Лучший ответ Сообщение было отмечено rotciv как решение

Решение

Используя ленивый алгоритм (для нахождения минимальных комбинаций):
C++
1
2
3
4
5
6
7
8
9
10
11
12
#include <regex>
#include <string>
#include <iostream>
 
int main()
{
    const std::string str = "This is the long \"string having \"some words \"in quotes\"";
    std::regex reg("\".*?\"");
    std::sregex_iterator beg(str.begin(), str.end(), reg), end;
    while (beg != end)
        std::cout << beg++->str() << std::endl;
}
Если нужен жадный алгоритм (чтобы нашло только одно соответствие максимальной длины) - уберите вопросительный знак в регулярке.
Использую ++-> специально т.к. выглядит классно Если не понятно - там (beg++)->str()

Добавлено через 23 секунды
Цитата Сообщение от rotciv Посмотреть сообщение
Покритикуйте плз. Может быть, как-то поэлегантнее можно?
Конечно. Задача для регулярок, а не велосипедов.

Добавлено через 1 минуту
Никаких проверок, спокойный выход за границу. Не подключён хедер string.

Добавлено через 6 минут
Цитата Сообщение от rotciv Посмотреть сообщение
Где почитать про использование regex?
http://en.cppreference.com/w/cpp/regex
https://ru.wikipedia.org/wiki/... 5%ED%E8%FF
1
0 / 0 / 0
Регистрация: 04.03.2015
Сообщений: 55
14.04.2015, 14:59  [ТС]
Цитата Сообщение от MrGluck Посмотреть сообщение
Не подключён хедер string
Я его, кстати, выкинул потому, что и без него скомпилировалось. Почему?
0
1373 / 596 / 199
Регистрация: 02.08.2011
Сообщений: 2,886
14.04.2015, 15:01
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
44
45
#include <algorithm>
#include <iostream>
#include <iterator>
#include <vector>
 
using namespace std;
 
vector<string> GetSFromQout(const string &S){
 
    string temp;
    vector<string> v;
    vector<string::const_iterator> v2;
 
        //Забираем позиции кавычек
    for (string::const_iterator it=S.begin();it!=S.end();it++)  {
        if (*it=='\"')    v2.push_back(it);
    }
 
   if (v2.size()%2) v2.push_back(v2.at(v.size()));  //Если кавычек нечетное число, нужно сделать четное число позиций
 
    //СОбираем слова по выбранным позициям
     for (int i=0;i<v2.size();i+=2){
          std::copy(v2.at(i),v2.at(i+1),back_inserter(temp));
          v.push_back(temp+'\"');
          temp.clear();
     }
 
 
if (!(v2.size()%2)) v.pop_back();  //Если было нечетное число кавычек, то убиваем что добавили
 
    return v;
}
 
int main (void){
    setlocale(LC_ALL,"");
 
    string S1="Th \"str_1\"   some words \"str 2\" \"str____3\"   \"222"; //Незаконченные кавычки, значит не обособлено
    vector<string> S2=GetSFromQout(S1);
 
 for (int i=0;i<S2.size();i++) cout<<S2.at(i)<<"\n";
 
 
 
 return 0;
}
1
Форумчанин
Эксперт CЭксперт С++
 Аватар для MrGluck
8216 / 5047 / 1437
Регистрация: 29.11.2010
Сообщений: 13,453
14.04.2015, 15:04
Цитата Сообщение от rotciv Посмотреть сообщение
Я его, кстати, выкинул потому, что и без него скомпилировалось. Почему?
Потому что студия (или другой компиль, который вы использовали) неявно подключила string в потрохах iostream. Это не значит, что в другом компиляторе код будет компилироваться. Лучше явно подключать хедеры, в которых определены функции или классы.
1
0 / 0 / 0
Регистрация: 04.03.2015
Сообщений: 55
14.04.2015, 15:48  [ТС]
Цитата Сообщение от MrGluck Посмотреть сообщение
std::sregex_iterator beg(str.begin(), str.end(), reg), end;
Похоже, что у меня С++11 поддержки нет.

Добавлено через 37 минут
Цитата Сообщение от daslex Посмотреть сообщение
Код C++
Спасибо, но есть маленький прокол в алгоритме.

Если исходное число кавычек было четное, то последний элемент v все равно будет удален.
А в этом случае он должен остаться.

Проверяем - если убрать последнюю кавычку (перед 222), то на выходе пропадает "str____3".
0
1373 / 596 / 199
Регистрация: 02.08.2011
Сообщений: 2,886
14.04.2015, 16:02
Лучший ответ Сообщение было отмечено rotciv как решение

Решение

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
44
45
46
47
48
#include <algorithm>
#include <iostream>
#include <iterator>
#include <vector>
 
using namespace std;
 
vector<string> GetSFromQout(const string &S){
 
    string temp;
    vector<string> v;
    vector<string::const_iterator> v2;
    bool flag=false;
 
    //Забираем позиции кавычек
    for (string::const_iterator it=S.begin();it!=S.end();it++)  {
        if (*it=='\"')   v2.push_back(it);
    }
 
   if (v2.size()%2) {
        v2.push_back(v2.at(v.size()));  //Если кавычек нечетное число, нужно сделать четное число позиций
        flag=true;
   }
    //СОбираем слова по выбранным позициям
     for (int i=0;i<v2.size();i+=2){
          std::copy(v2.at(i),v2.at(i+1),back_inserter(temp));
          v.push_back(temp+'\"');
          temp.clear();
     }
 
 
   if (flag) v.pop_back() ;//Если было нечетное число кавычек, то убиваем что добавили
 
    return v;
}
 
int main (void){
    setlocale(LC_ALL,"");
 
    string S1="Th \"str_1\"   some words \"str 2\" \"str____3\"   \"222"; //Незаконченные кавычки, значит не обособлено
    vector<string> S2=GetSFromQout(S1);
 
 for (int i=0;i<S2.size();i++) cout<<S2.at(i)<<"\n";
 
 
 
 return 0;
}
1
0 / 0 / 0
Регистрация: 04.03.2015
Сообщений: 55
14.04.2015, 16:12  [ТС]
Цитата Сообщение от daslex Посмотреть сообщение
Код C++
Отлично работает, спасибо!
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
14.04.2015, 16:12
Помогаю со студенческими работами здесь

Обернуть часть строки (от кавычки до кавычки) в тег <p>
Допустим есть срока : var ex = ' привет &quot;человек&quot;привет ' Нужно (человек) одеть в тег &lt;p&gt;. Тоесть то что находиться между...

Что обозначают тройные кавычки (двойные кавычки)?
res1 = wsh.Run(&quot;&quot;&quot;C:\FPC\2.6.0\bin\i386-win32\fpc.exe&quot;&quot; d:\script\sumcifr.pas&quot;, 1, true) подскажите пожалуйста почему в строке где...

Какую премию получит брокер, если сумма заключенная за этот составляет Z евро?
III) Брокерская компания, по результатам года платит работникам премию в размере X% из суммы, которую брокер заключил за этот год, если...

Как засунуть кавычки в кавычки?
string a = x.Replace(&quot;&quot;&quot;, &quot;&quot;) Такое выражение не прокатывает Также не удается поставить в кавычки символ \

Как обернуть кавычки в кавычки
Здравствуйте! Пробую обернуть кавычки в кавычки но пока оборачивается весь текст: $input_lines = &quot;test1 &quot;test2&quot;...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
13
Ответ Создать тему
Новые блоги и статьи
Новый CodeBlocs. Версия 25.03
palva 04.01.2026
Оказывается, недавно вышла новая версия CodeBlocks за номером 25. 03. Когда-то давно я возился с только что вышедшей тогда версией 20. 03. С тех пор я давно снёс всё с компьютера и забыл. Теперь. . .
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение. И на уровне агентов добавится между грибами или бактериями взаимодействий. До того я пробовал подход через многомерные массивы,. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru