Андрeй
Зарегистрирован: 13.08.2007 Сообщения: 4
|
Добавлено: Пт Окт 05 2007 13:47 Заголовок сообщения: с++ и pcre - мультисегмениный поиск |
|
|
Приветсвую всем, узаю рег. выражения и PCRE_DFA_EXEC в частности, читал маны, но как-то недопонял как организовать поиск в нескольких сегментах(те когда строка скармливается функции по чатям). Пример кода привожу, подскажите как должно быть чтобы в результате было также 03.11.2002
#include <stdio.h>
#include <pcre.h>
#include<string.h>
int main(int argc, char* argv[])
{
pcre *f; /* переменная для хранения преобразованного шаблона */
pcre_extra *f_ext; /* переменная для хранения дополнительных данных */
char *pattern="([0-2][1-9]|[3][0-1])[-/\\.]([0][1-9]|[1][0-2])[-/\\.](\\d{2})?(\\d{2})"; /* шаблон */
const char *errstr; /* буфер для сообщения об ошибке */
int errchar; /* номер символа */
char *str="01.11.2002 Сегодня - 02.11.2002 dsdd03.11"; /* строка для примера */
char *str2=".2002sdcsdcsdc"; /* строка для примера */
int vector[50]; /* массив для результатов */
int vecsize=50; /* размер массива */
int wspace[1024];
int pairs; /* количество найденных пар */
char buff1[200]; /* буфер для функции pcre_copy_substring */
const char *buff2; /* буфер для функции pcre_get_substring */
const char **buff3; /* для функции pcre_get_substring_list */
int i,j;printf("Test\n");
if((f=pcre_compile(pattern,PCRE_CASELESS|PCRE_MULTILINE,&errstr,&errchar,NULL))==NULL)
{
printf("Ошибка: %s\nСимвол N%i\nШаблон:%s\n",errstr,errchar,pattern);
}
else
{
i=0;
while((pairs = pcre_dfa_exec(f, NULL,str,strlen(str),i,PCRE_PARTIAL,vector,vecsize,wspace,1024))>0)
{
if(pcre_copy_substring(str,vector,pairs,0,buff1,199)<0)
printf("Ошибка pcre_copy_substring!\n");
else
printf("pcre_copy_substring:\nподстрока: %s\n",buff1);
i+=vector[1];
}
i=0;
while((pairs = pcre_dfa_exec(f, NULL,str2,strlen(str2),i,PCRE_PARTIAL+PCRE_DFA_RESTART,vector,vecsize,wspace,1024))>0)
{
if(pcre_copy_substring(str,vector,pairs,0,buff1,199)<0)
printf("Ошибка pcre_copy_substring!\n");
else
printf("pcre_copy_substring:\nподстрока: %s\n",buff1);
i+=vector[1];
}
}
return 0;
}
//EOF |
|