bâtiment sur @ exemple Tim pour faire une méthode autonome: (. L'exemple de test est un command that lists all files in a directory and its subdirectories, recursively, in chronological order)
import java.io.BufferedReader;
import java.io.File;
import java.io.InputStreamReader;
import java.util.ArrayList;
public class Shell {
/** Returns null if it failed for some reason.
*/
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);
//There should really be a timeout here.
if (0 != process.waitFor())
return null;
return output;
} catch (Exception e) {
//Warning: doing this is no good in high quality applications.
//Instead, present appropriate error messages to the user.
//But it's perfectly fine for prototyping.
return null;
}
}
public static void main(String[] args) {
test("which bash");
test("find . -type f -printf '%[email protected]\\\\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);
}
}
Par Si quelqu'un peut me dire pourquoi j'ai besoin de quatre et huit barres obliques inverses, au lieu de deux et quatre, je peux apprendre quelque chose. Il y a un autre niveau de non-évitement qui se produit que ce que je compte. Edit: J'ai essayé ce même code sous Linux, et il s'avère que j'ai besoin de la moitié moins de backslashes dans la commande de test! (C'est-à-dire: le nombre attendu de deux et quatre.) Maintenant, ce n'est plus juste bizarre, c'est un problème de portabilité.
'cat' et' csh' n'ont rien à voir l'un avec l'autre. – Bombe
Je peux comprendre la question pour d'autres commandes, mais pour chat: pourquoi diable ne pas simplement lu dans le fichier? – Atmocreations
Tout le monde se trompe la première fois - exec() de Java n'utilise pas le shell du système sous-jacent pour exécuter la commande (comme l'indique kts). La redirection et la tuyauterie sont des caractéristiques d'un vrai shell et ne sont pas disponibles depuis exec() de Java. – SteveD