Подтвердить что ты не робот

Присоедините массив строк в Apex

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

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

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

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

4b9b3361

Ответ 1

Вы можете сделать это с 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

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

Ответ 2

Обратите внимание, что если строковый объект слишком велик, исключение 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 lists 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');