From 78039785a656f5c8f130b4c199284256007772f5 Mon Sep 17 00:00:00 2001 From: luxiaotao1123 <t1341870251@163.com> Date: 星期三, 18 十二月 2024 12:49:59 +0800 Subject: [PATCH] # --- zy-acs-manager/src/main/java/com/zy/acs/manager/core/service/AvoidWaveCalculator.java | 96 +++++++++++++++++++---------------------------- 1 files changed, 39 insertions(+), 57 deletions(-) diff --git a/zy-acs-manager/src/main/java/com/zy/acs/manager/core/service/AvoidWaveCalculator.java b/zy-acs-manager/src/main/java/com/zy/acs/manager/core/service/AvoidWaveCalculator.java index 9af3df8..c8046ed 100644 --- a/zy-acs-manager/src/main/java/com/zy/acs/manager/core/service/AvoidWaveCalculator.java +++ b/zy-acs-manager/src/main/java/com/zy/acs/manager/core/service/AvoidWaveCalculator.java @@ -102,74 +102,56 @@ AgvModel agvModel = agvModelService.selectByType(AgvModelType.CTU_BOX_TRANSPORT_AGV.toString()); // can be optimized Double avoidDistance = MapDataUtils.getVehicleWaveSafeDistance(agvModel.getDiameter(), MapDataConstant.MAX_DISTANCE_BETWEEN_ADJACENT_AGV_FACTOR); - long startTime = System.currentTimeMillis(); - Resource resource = new ClassPathResource("agv.py"); File tempScript = null; - try { - InputStream is = resource.getInputStream(); - tempScript = File.createTempFile("agv", ".py"); - tempScript.deleteOnExit(); + InputStream is = resource.getInputStream(); + tempScript = File.createTempFile("agv", ".py"); + tempScript.deleteOnExit(); - Files.copy(is, tempScript.toPath(), StandardCopyOption.REPLACE_EXISTING); - tempScript.setExecutable(true); + Files.copy(is, tempScript.toPath(), StandardCopyOption.REPLACE_EXISTING); + tempScript.setExecutable(true); - ProcessBuilder processBuilder = new ProcessBuilder( - "python" // 鎴栬�� "python3" 鍙栧喅浜庣郴缁熼厤缃� - , tempScript.getAbsolutePath() - , String.valueOf(avoidDistance) - , redisProperties.getHost() - , redisProperties.getPassword() - , String.valueOf(redisProperties.getPort()) - , String.valueOf(redisProperties.getIndex()) - ); + ProcessBuilder processBuilder = new ProcessBuilder( + "python" // 鎴栬�� "python3" 鍙栧喅浜庣郴缁熼厤缃� + , tempScript.getAbsolutePath() + , String.valueOf(avoidDistance) + , redisProperties.getHost() + , redisProperties.getPassword() + , String.valueOf(redisProperties.getPort()) + , String.valueOf(redisProperties.getIndex()) + ); - processBuilder.redirectErrorStream(true); + processBuilder.redirectErrorStream(true); -// File file = resource.getFile(); -// ProcessBuilder processBuilder = new ProcessBuilder( -// "python" -// , file.getAbsolutePath() -// , String.valueOf(avoidDistance) -// , redisProperties.getHost() -// , redisProperties.getPassword() -// , String.valueOf(redisProperties.getPort()) -// , String.valueOf(redisProperties.getIndex()) -// ); -// processBuilder.redirectErrorStream(true); + Process process = processBuilder.start(); - Process process = processBuilder.start(); + BufferedReader reader = new BufferedReader(new InputStreamReader(process.getInputStream())); + String line; + StringBuilder builder = new StringBuilder(); + while ((line = reader.readLine()) != null) { + builder.append(line); + } - BufferedReader reader = new BufferedReader(new InputStreamReader(process.getInputStream())); - String line; - StringBuilder builder = new StringBuilder(); - while ((line = reader.readLine()) != null) { - builder.append(line); + int exitCode = process.waitFor(); + if (exitCode != 0) { + log.error("Python script exited with error code: {}", exitCode); + log.error("python error:{}", builder.toString()); + return; + } + reader.close(); + + if (builder.length() <= 0) { + return; + } + + String result = builder.toString(); + + if (!Cools.isEmpty(result)) { + if (!"1".equals(result)) { + log.error("Failed to call python"); } - - int exitCode = process.waitFor(); - if (exitCode != 0) { - log.error("Python script exited with error code: {}", exitCode); - log.error("python error:{}", builder.toString()); - return; - } - reader.close(); - - if (builder.length() <= 0) { - return; - } - - String result = builder.toString(); - - if (!Cools.isEmpty(result)) { - if (!"1".equals(result)) { - log.error("Failed to call python"); - } - } - } catch (IOException | InterruptedException e) { - e.printStackTrace(); } // log.error("python finish {}", System.currentTimeMillis() - startTime); -- Gitblit v1.9.1