Присоединить массив строк в Apex - PullRequest
16 голосов
/ 27 февраля 2012

Используя Apex, я хочу разбить строку и затем воссоединить ее с оператором 'AND' в качестве разделителя.

Я успешно разбил строку, но у меня возникла проблема с повторным соединением.

 String [] ideaSearchText = searchText.Split(' ');
 // How to rejoin the array of strings with 'AND'?

Как я могу это сделать?

Ответы [ 2 ]

26 голосов
/ 28 февраля 2013

Вы можете сделать это начиная с v26 (зима 13), передав String[] в String.join().

String input = 'valueOne valueTwo valueThree';
String[] values = input.split(' ');
String result = String.join( values, ' AND ' );

Анонимный выход Apex, вызывающий System.debug(result):

21:02:32.039 (39470000)|EXECUTION_STARTED
21:02:32.039 (39485000)|CODE_UNIT_STARTED|[EXTERNAL]|execute_anonymous_apex
21:02:32.040 (40123000)|SYSTEM_CONSTRUCTOR_ENTRY|[3]|<init>()
21:02:32.040 (40157000)|SYSTEM_CONSTRUCTOR_EXIT|[3]|<init>()
21:02:32.040 (40580000)|USER_DEBUG|[5]|DEBUG|valueOne AND valueTwo AND valueThree

Документация Salesforce API: http://www.salesforce.com/us/developer/docs/apexcode/Content/apex_methods_system_string.htm

0 голосов
/ 19 октября 2018

Обратите внимание, что если строковый объект слишком велик, вы получите исключение Regex too complicated. В этом случае вы можете сделать что-то вроде следующего:

Blob blobValue = (Blob)record.get(blobField);

// Truncate string then split on newline, limiting to 11 entries
List<String> preview = blobValue.toString().substring(0,1000).split('\n', 11);

// Remove the last entry, because The list’s last entry contains all 
// input beyond the last matched delimiter.
preview.remove(preview.size()-1);

// In my use-case, I needed to return a string, and String.join() works 
// as the reverse of split()    
return String.join(preview, '\n');
...