Кодировать символы в символьные объекты для XML - PullRequest
2 голосов
/ 21 января 2011

У меня есть переменная, определенная как:

D content                     1280A   CONST 

Мне нужно найти символы ", &, ', <, > и заменить их на:

&quot;, &amp;, &apos;, &lt; и &gt;соответственно.

Я видел некоторые функции XML в языке, но они, похоже, не то, что мне нужно.Но я могу ошибаться, поэтому здесь я спрашиваю.

Использование RPGLE, freeform.

Решение : Возможно, не очень RPG-иш, но это сработало

P encode          B             
D                 PI          1280A        
D content                     1280A   CONST    
D outStr          S           1280A                       
D strDsp          S             50A 
 /free 
   outStr = %trim(content);   
   outStr = replaceAll('&' : '&amp;' : outStr);  
   outStr = replaceAll('"' : '&quot;' : outStr);  
   outStr = replaceAll('''' : '&apos;' : outStr);     
   outStr = replaceAll('>' : '&gt;' : outStr);    
   outStr = replaceAll('<' : '&lt;' : outStr);   
   return outStr;                               
 /end-free                     
P                 E        


P*** Procedure: replaceAll  ************************************  
P*** IN: character to replace, replacement text, source       
P*** OUT: transformed string             
P replaceAll      B                          
D                 PI          1280A          
D character                      1A   CONST           
D rText                         10A   CONST    
D content                     1280A   CONST         
D outStr          S           1280A   
D dspStr          S             50A                      
D rSize           S              3P 0                                       //replacement text size
D index           S              3P 0                                       //cur str index  
D cntSize         S              3P 0                                       //content size
 /free                                                   
   rSize = %len(%trim(rText));                               
   cntSize = %len(%trim(content));                          
   outStr = content;                                            
   for i = 1 to cntSize; //scan starts at character 1 not 0
      index = %scan(character : outStr : i);
      if index = 0;            
    leave;                        
      endif;                                   
      outStr = %replace(%trim(rText) : outStr : index : 1);    
      i = index + 1;                    
   endfor;          
   return outStr; 
 /end-free 
P                 E         

Ответы [ 2 ]

4 голосов
/ 24 января 2011

Может быть, это просто с моей стороны, но будет ли достаточно просто использовать встроенную функцию% replace?Я имею в виду, вам придется использовать его повторно, для разных вещей, которые вы заменяете.Но есть ли особые случаи такого рода поражения бессмысленной заменой?(Я думаю о том, как часто люди пытаются просто анализировать CSV, например, бездумно разбивая запятые. Это не подходит для некоторых наборов данных.)

3 голосов
/ 06 марта 2015

Существует функция% scanrpl, которая заменяет все вхождения строки другой строкой.Похоже, горячий билет.

...