Posted: Wed Jan 14, 2009 10:06 am Post subject: Разбивка текста на строки заданной длины
Бывает, что нужно разбить текст на строки заданной длины с учетом переноса по словам, а слова могут разделяться разными разделителями - пробел, запятая, точка с запятой и тд. Найденный саповские ФМы позволяют указать только один разделитесь, в связи с чем и было когда то сотворено нижеследующее:
Code:
************************************************************************
* Разбивает текст по словам на строки заданной длины
************************************************************************
FORM SPLITWORDS TABLES "" out:
STRINGS TYPE TABLE """ таблица форматированных строк
USING "" in:
WIDTH TYPE P """ ширина текста (1..16834)
SRC_LINE TYPE C """ разбиваемый текст
VALUE(DELIMITER) TYPE C. """ разделители слов
DATA:
TEXT(16834) TYPE C,
STRING(16834) TYPE C,
CHAR TYPE C,
CURPOS TYPE P VALUE 0,
SPCPOS TYPE P VALUE 0,
STRTPOS TYPE P VALUE 0,
TEXTLEN TYPE P,
TMP TYPE P.
TEXT = SRC_LINE.
TEXTLEN = STRLEN( TEXT ).
IF TEXTLEN = 0.
APPEND ' ' TO STRINGS.
EXIT.
ENDIF.
WHILE CURPOS <= TEXTLEN.
CHAR = TEXT+CURPOS(1).
IF CHAR CA DELIMITER. """ найден разделитель слов
SPCPOS = CURPOS + 1. """ сохранение позиции разделителя
ENDIF.
TMP = CURPOS - STRTPOS. """ длина текущей строки
IF TMP >= WIDTH. """ превышена граница строки?
IF SPCPOS = 0. """ разделителей не было?
SPCPOS = CURPOS. """ разбиваем длинное слово по строке
ENDIF.
TMP = SPCPOS - STRTPOS. """ длина полученной строки
IF TMP > WIDTH.
TMP = WIDTH. """ ограничение длины строки
ENDIF.
STRING = TEXT+STRTPOS(TMP).
APPEND STRING TO STRINGS. """ добавление в табличку
CLEAR STRING.
STRTPOS = SPCPOS.
SPCPOS = 0.
ENDIF.
ADD 1 TO CURPOS.
ENDWHILE.
SUBTRACT 1 FROM SPCPOS.
IF SPCPOS <= TEXTLEN AND SPCPOS > 0.
TMP = SPCPOS - STRTPOS.
IF TMP > 0.
STRING = TEXT+STRTPOS(TMP).
APPEND STRING TO STRINGS.
ENDIF.
ENDIF.
ENDFORM.
Пример:
Code:
DATA: TEXT(200)
, TBL(80) TYPE C OCCURS 2 WITH HEADER LINE
.
START-OF-SELECTION.
TEXT = 'Мама мыла раму где то там,зачем то и: почему'.
PERFORM SPLITWORDS TABLES TBL USING 8 TEXT ',: '.
You cannot post new topics in this forum You cannot reply to topics in this forum You cannot edit your posts in this forum You cannot delete your posts in this forum You cannot vote in polls in this forum You cannot attach files in this forum You can download files in this forum
All product names are trademarks of their respective companies. SAPNET.RU websites are in no way affiliated with SAP AG. SAP, SAP R/3, R/3 software, mySAP, ABAP, BAPI, xApps, SAP NetWeaver and any other are registered trademarks of SAP AG. Every effort is made to ensure content integrity. Use information on this site at your own risk.