Основываясь на примере @ Tim, чтобы создать автономный метод:
import java.io.BufferedReader;
import java.io.File;
import java.io.InputStreamReader;
import java.util.ArrayList;
public class Shell {
public static ArrayList<String> command(final String cmdline,
final String directory) {
try {
Process process =
new ProcessBuilder(new String[] {"bash", "-c", cmdline})
.redirectErrorStream(true)
.directory(new File(directory))
.start();
ArrayList<String> output = new ArrayList<String>();
BufferedReader br = new BufferedReader(
new InputStreamReader(process.getInputStream()));
String line = null;
while ( (line = br.readLine()) != null )
output.add(line);
if (0 != process.waitFor())
return null;
return output;
} catch (Exception e) {
return null;
}
}
public static void main(String[] args) {
test("which bash");
test("find . -type f -printf '%T@\\\\t%p\\\\n' "
+ "| sort -n | cut -f 2- | "
+ "sed -e 's/ /\\\\\\\\ /g' | xargs ls -halt");
}
static void test(String cmdline) {
ArrayList<String> output = command(cmdline, ".");
if (null == output)
System.out.println("\n\n\t\tCOMMAND FAILED: " + cmdline);
else
for (String line : output)
System.out.println(line);
}
}
(Тестовый пример - это команда, которая рекурсивно перечисляет все файлы в каталоге и его подкаталогах в хронологическом порядке .)
Кстати, если кто-нибудь скажет мне, зачем мне там четыре и восемь обратных слешей вместо двух и четырех, я кое-чему научусь. Есть еще один уровень непредвиденных обстоятельств, чем я рассчитываю.
Изменить: просто попробовал этот же код в Linux, и оказалось, что мне нужно вдвое меньше обратных косых черт в тестовой команде! (То есть ожидаемое число два и четыре.) Теперь это уже не просто странно, это проблема переносимости.
cat
иcsh
не имеют ничего общего друг с другом.