Присоедините массив строк в Apex
Используя Apex, я хочу разбить строку, а затем снова присоединить ее к оператору "AND" в качестве разделителя.
Я разделил строку успешно, но у меня возникла проблема с воссоединением.
String [] ideaSearchText = searchText.Split(' ');
// How to rejoin the array of strings with 'AND'?
Как я могу это сделать?
Ответы
Ответ 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');