Java-代碼段-http接口調用自身服務中的其他http接口(mock)-并建立socket連接發送和接收報文實例

最新版本更新
https://code.jiangjiesheng.cn/article/367?from=csdn

推薦 《高并發 & 微服務 & 性能調優實戰案例100講 源碼下載》

1. controller入口

    @ApiOperation("模擬平臺端+現場機socket交互過程,需要Authorization")@PostMapping(path = "/testSocketBusiness")public ResponseBean<HashMap<Object, Object>> testSocketBusiness(@RequestBody SocketTestClient.SocketAllParams socketAllParams) {// 建立socket連接  "\n")HashMap<Object, Object> res = socketTestClient.doTestAll(socketAllParams.getFirstUrlRequest(), socketAllParams.getSocketMsgList(), socketAllParams.getAutoUseNowDataTime());return new ResponseBean<>(200, "請求結束", res);}

1.1 接口入參示例及說明

{"firstUrlRequestxxxxx": {"url": "/your http api/remoteControl","method": "PUT","urlParams": {"monitorId": 3319,"cn": "3020","polId": "md0501","infoId": "i42002"}},"socketMsgList": ["ST=32;CN=3020;PW=123456;MN=887799;Flag=5;CP=&&DataTime=20250529105000;PolId=md0501;DT=201;VaseNo=4;i33022-Info=0;i33028-Info=1&&"],"autoUseNowDataTime": true,"【示例非必要不改動】反控入參示例(前不要長度、不要QN,后不要結尾,DataTime是否自動更新取決于autoUseNowDataTime)": {"firstUrlRequest": {"url": "/your http api/remoteControl","method": "PUT","urlParams": {"monitorId": 3319,"cn": "3020","polId": "md0501","infoId": "i42002"}},"socketMsgList": ["ST=91;CN=9011;PW=123456;MN=7899871;Flag=4;CP=&&QnRtn=1&&","ST=32;CN=3020;PW=123456;MN=7899871;Flag=4;CP=&&DataTime=20250528111758;PolId=md0501;i42002-Info=2&&","ST=91;CN=9012;PW=123456;MN=7899871;Flag=4;CP=&&ExeRtn=1&&"],"autoUseNowDataTime": true},"【示例非必要不改動】監測數據入參示例(前不要長度、不要QN,后不要結尾,DataTime是否自動更新取決于autoUseNowDataTime)": {"socketMsgList": ["ST=32;CN=2011;PW=123456;MN=7899871;Flag=5;CP=&&DataTime=20250527105200;w01018-Rtd=8.8,w00000-Flag=N;w01018-Rtd=444.7,w01018-SampleTime=20250527105100,w01018-Flag=D&&"],"autoUseNowDataTime": false},"一次采集日志:": ["tail -200f /home/logs/yourProject/collect/connect.log","tail -200f /home/logs/yourProject/collect/receive.log [重點]","tail -200f /home/logs/yourProject/collect/send.log","tail -200f /home/logs/yourProject/debug.log [重點]","tail -200f /home/logs/yourProject/error.log"]
}

1.2 接口出參示例

{"code": 200,"msg": "請求結束","data": {"請求結束,當期是監測數據上傳模式,返回qn列表:": ["20250529132932726"]},"timestamp": "2025-05-29 13:29:36","traceId": "cb9557eaed1543aa8749bf2a545816ef"
}

2. mock test方式調用自身controller下的http接口并建立socket連接發送和接收報文實例

SocketTestClient.java

package cn.jiangjiesheng.code.service.common;import cn.hutool.core.date.DateUtil;
import cn.hutool.json.JSONUtil;
import cn.jiangjiesheng.code.core.utils.ControllerInvoker;
import cn.jiangjiesheng.code.core.utils.HttpServletUtil;
import cn.jiangjiesheng.code.core.utils.StringUtils;
import cn.jiangjiesheng.code.exception.GnException;
import com.google.api.client.util.Lists;
import com.google.common.collect.Maps;
import lombok.Data;
import lombok.extern.slf4j.Slf4j;
import org.apache.commons.collections.CollectionUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Component;import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.IOException;
import java.io.OutputStreamWriter;import java.io.*;
import java.net.Socket;
import java.util.Date;
import java.util.HashMap;
import java.util.List;
import java.util.regex.Matcher;
import java.util.regex.Pattern;@Component
@Slf4j
public class SocketTestClient {// 配置參數:socket服務器IP/端口@Value("${ecp-collector.url}")private String socketIP;private static final int SOCKET_PORT = 16010;// 復用socketprivate static volatile Socket socket;private static final Object lock = new Object();// 建立連接使用,核心是PW=123456;MN=7899871private static final String BUILD_MN_CONNECT_FIRST_TIME = "QN=20250523094003516;ST=32;CN=2011;PW=%s;MN=%s;Flag=5;CP=&&DataTime=20250525093100;w00000-Rtd=0.00;&&4540"; // 固定內容// 發送間隔(毫秒)private static final long SEND_INTERVAL = 500;@Autowiredprivate ControllerInvoker controllerInvoker;/*** 模擬云平臺和現場機交互的接口* (整個交互的多條報文在一個接口入參中寫完,就不用通過socket工具來測試了,* 一次采集一套流程好像還有10秒內的限制,通過接口調用就沒這些問題了。)** @param urlObj             模擬第一次業務觸發* @param socketMsgList      其他交互報文* @param autoUseNowDataTime 是否自動更新DataTime,默認是* @return 返回qn*/public HashMap<Object, Object> doTestAll(FirstUrlRequest urlObj, List<String> socketMsgList, Boolean autoUseNowDataTime) {//反控的qnString qn = null;boolean isReverseControlMode = false;//記錄下qn,返回便于查驗List<String> qnList = Lists.newArrayList();try {//單例模式復用socketconnectToServer();if (CollectionUtils.isNotEmpty(socketMsgList)) {// 獲取輸出流(用于發送數據)OutputStream out = socket.getOutputStream();// 字符集String CHARSET = "UTF-8";BufferedWriter writer = new BufferedWriter(new OutputStreamWriter(out, CHARSET));//觸發第1個接口請求if (urlObj != null && StringUtils.isNotBlank(urlObj.getUrl())) {//發送建立連接使用String msgOne = socketMsgList.get(0);// 正則匹配 PW 和 MN 的值String pw = extractValue(msgOne, "PW=([^;]+);");String mn = extractValue(msgOne, "MN=([^;]+);");log.info("doTestAll,PW = {}", mn);log.info("doTestAll,MN = {}", mn);sendMessage(writer, handleFinalMsg(String.format(BUILD_MN_CONNECT_FIRST_TIME, pw, mn)));//還要有首選String authorization = getRequest().getHeader("Authorization");if (StringUtils.isBlank(authorization)) {throw new GnException("請添加Authorization頭");}String result = null;try {try {//這里要等待建立好mn連接,必須,否則會報"鏈接不可用"Thread.sleep(SEND_INTERVAL);} catch (InterruptedException e) {Thread.currentThread().interrupt();throw new GnException("發送線程被中斷");}// 直接post get 方式調用會阻塞//  result = HttpConnectionsUtils.requestWithBody(urlObj.getUrl(), urlObj.getMethod(), null, JSONUtil.toJsonStr(urlObj.getUrlParams()), authorization);result = controllerInvoker.invokeController(urlObj.getUrl(), urlObj.getMethod(), JSONUtil.toJsonStr(urlObj.getUrlParams()), authorization);} catch (Exception e) {throw new GnException("當前反控接口調用失敗:" + e.getMessage());}qn = JSONUtil.parseObj(result).getStr("data", "");if (StringUtils.isBlank(qn)) {throw new GnException("當前反控接口調用失敗");}}//替換qn 和 DataTimeString datetime = null;if (autoUseNowDataTime == null) {autoUseNowDataTime = true;}if (autoUseNowDataTime) {datetime = DateUtil.format(new Date(), "yyyyMMddHHmmss");}//是否是反控模式isReverseControlMode = qn != null;//執行其他報文請求for (String msg : socketMsgList) {if (isReverseControlMode) {addQnList(qnList, qn);} else {//監測數據上傳,這里重新生成qnqn = DateUtil.format(new Date(), "yyyyMMddHHmmssSSS");addQnList(qnList, qn);}if (msg.startsWith("QN=")) {msg = msg.replaceFirst("QN=[^;]+;", String.format("QN=%s;", qn));} else {msg = String.format("QN=%s;", qn) + msg;}if (datetime != null && msg.contains("DataTime=")) {msg = msg.replaceFirst("DataTime=[^;]+;", String.format("DataTime=%s;", datetime));}msg = handleFinalMsg(msg);try {Thread.sleep(SEND_INTERVAL);} catch (InterruptedException e) {Thread.currentThread().interrupt();log.info("發送線程被中斷");break;}sendMessage(writer, msg);}// writer.close(); socket也會關閉}HashMap<Object, Object> qnMap = Maps.newHashMap();String key = String.format("請求結束,%s,返回qn列表:", isReverseControlMode ? "當前是反控模式(1個qn)" : "當期是監測數據上傳模式");qnMap.put(key, qnList);return qnMap;} catch (IOException e) {log.info("連接或通信異常: " + e.getMessage());throw new GnException("連接或通信異常: " + e.getMessage());} catch (Exception e) {throw new GnException("當前反控接口調用失敗:" + e.getMessage());} finally {//disconnect();}}private static void addQnList(List<String> qnList, String qn) {if (!qnList.contains(qn)) {qnList.add(qn);}}/*** 處理成最終的報文格式** @param msg* @return*/private static String handleFinalMsg(String msg) {//判斷是否需要組裝成完整的報文if (msg.startsWith("QN")) {// 找到最后一個 "&&" 的位置int index = msg.lastIndexOf("&&");if (index > 0 && !msg.endsWith("&&")) {//先截斷msg = msg.substring(0, index + 2); // 保留 "&&}int length = msg.length();String msgStart = String.format("##%04d", length);msg = msgStart + msg;}//這個應該緊跟上面的邏輯,拼接的內容好像不重要if (msg.endsWith("&&")) {msg += "4540";}return msg;}/*** 獲取當前請求的request對象** @author xuyuxiang* @date 2020/3/30 15:10*/public static HttpServletRequest getRequest() {ServletRequestAttributes requestAttributes = (ServletRequestAttributes) RequestContextHolder.getRequestAttributes();if (requestAttributes == null) {throw new GnException("請求的參數異常");} else {return requestAttributes.getRequest();}}// 提取方法private static String extractValue(String input, String regex) {Pattern pattern = Pattern.compile(regex);Matcher matcher = pattern.matcher(input);if (matcher.find()) {return matcher.group(1);}return null;}// 封裝發送方法:添加 \r\n 并刷新private void sendMessage(BufferedWriter writer, String message) {try {// 添加回車換行 ,應該只要 \nwriter.write(message + "\r\n");writer.flush();log.info("doTestAll,已發送報文 {}", message);} catch (IOException e) {log.info("doTestAll,發送報文失敗 {}", message);}}// 啟動一個線程接收服務器響應(可選)private void startServerResponseThread(Socket socket) {new Thread(() -> {try (InputStream in = socket.getInputStream();BufferedReader reader = new BufferedReader(new InputStreamReader(in))) {String responseLine;while ((responseLine = reader.readLine()) != null) {log.info(" 收到來自服務器的報文: " + responseLine);}} catch (IOException e) {log.info(" 接收服務器報文失敗: " + e.getMessage());}}).start();}/*** 單例模式復用socket*/public void connectToServer() {if (socket == null || socket.isClosed()) {//|| socket.isConnected()只表示這個 Socket 對象是否曾經成功連接過一次。synchronized (lock) {if (socket == null || socket.isClosed()) {//|| socket.isConnected()只表示這個 Socket 對象是否曾經成功連接過一次。try {socket = new Socket(socketIP, SOCKET_PORT);// 可以在這里配置 socket 參數,如設置超時時間log.info("成功連接到socket服務器:{}:{}", socketIP, SOCKET_PORT);SocketMessageReceiver receiver = new SocketMessageReceiver(socket, new MessageHandler() {@Overridepublic void onMessageReceived(String message) {log.info("收到socket回復消息:{}", message);}@Overridepublic void onConnectionClosed() {log.info("socket斷開連接");}@Overridepublic void onError(Exception e) {log.info("socket連接發生錯誤", e);}});receiver.start();} catch (IOException e) {throw new GnException("socket連接異常:" + e.getMessage());}} else {log.info("socket已連接:{}:{}", socketIP, SOCKET_PORT);}}} else {log.info("socket已連接:{}:{}", socketIP, SOCKET_PORT);}}public void disconnect() {try {if (socket != null && !socket.isClosed()) {socket.close();socket = null;}} catch (IOException e) {throw new GnException("socket關閉異常:" + e.getMessage());}}/*** 模擬第一次業務觸發*/@Datapublic static class FirstUrlRequest {private String url;private String method;private Object urlParams;}@Datapublic static class SocketAllParams {//模擬第一次業務觸發private FirstUrlRequest firstUrlRequest;//其他交互報文private List<String> socketMsgList;//是否自動更新DataTime,默認是private Boolean autoUseNowDataTime;}interface MessageHandler {void onMessageReceived(String message);void onConnectionClosed();void onError(Exception e);}static class SocketMessageReceiver {private final Socket socket;private final MessageHandler handler;private volatile boolean running = true;public SocketMessageReceiver(Socket socket, MessageHandler handler) {this.socket = socket;this.handler = handler;}public void start() {new Thread(this::runLoop).start();}public void stop() {running = false;try {if (!socket.isClosed()) {socket.close();}} catch (IOException e) {handler.onError(e);}}private void runLoop() {try (InputStream in = socket.getInputStream();BufferedReader reader = new BufferedReader(new InputStreamReader(in))) {String line;while (running && (line = reader.readLine()) != null) {handler.onMessageReceived(line);}handler.onConnectionClosed();} catch (IOException e) {handler.onError(e);}}}
}

3. ControllerInvoker mock調用http接口代碼

ControllerInvoker.java

package cn.jiangjiesheng.code.core.utils;import cn.jiangjiesheng.code.exception.GnException;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.http.MediaType;
import org.springframework.mock.web.MockHttpServletResponse;
import org.springframework.stereotype.Service;
import org.springframework.web.servlet.HandlerAdapter;
import org.springframework.web.servlet.HandlerExecutionChain;
import org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerMapping;
import org.springframework.mock.web.MockHttpServletRequest;import java.nio.charset.StandardCharsets;/*** http調用Controller http代碼接口* 依賴* <dependency>*  <groupId>org.springframework.boot</groupId>*   <artifactId>spring-boot-starter-test</artifactId>*  <!--  <version>2.0.6.RELEASE</version>-->* </dependency>*/
@Service
public class ControllerInvoker {@Autowiredprivate RequestMappingHandlerMapping handlerMapping;@Autowired//有3個@Qualifier("requestMappingHandlerAdapter")private HandlerAdapter handlerAdapter;/*** http調用Controller http代碼接口,http不能直接調用自身服務的http接口,會阻塞* @param uri 不要server.servlet.context-path,示例:/your http api/remoteControl* @param method* @param jsonBody* @param authorization* @return* @throws Exception*/public String invokeController(String uri, String method,  String jsonBody, String authorization) throws Exception {MockHttpServletRequest request = new MockHttpServletRequest();request.setRequestURI(uri);request.setMethod(method.toUpperCase());request.addHeader("Authorization", authorization);request.setContentType(MediaType.APPLICATION_JSON_VALUE);request.setContent(jsonBody.getBytes(StandardCharsets.UTF_8));HandlerExecutionChain chain = handlerMapping.getHandler(request);if (chain == null) {throw new GnException("沒找到對應url: " + uri);}// 執行 Controller 方法MockHttpServletResponse response = new MockHttpServletResponse();handlerAdapter.handle(request, response, chain.getHandler());return new String(response.getContentAsByteArray(), StandardCharsets.UTF_8);}
}

最新版本更新
https://code.jiangjiesheng.cn/article/367?from=csdn

推薦 《高并發 & 微服務 & 性能調優實戰案例100講 源碼下載》

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/85277.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/85277.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/85277.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

基于遞歸思想的系統架構圖自動化生成實踐

文章目錄 一、核心思想解析二、關鍵技術實現1. 動態布局算法2. 樣式規范集成3. MCP服務封裝三、典型應用場景四、最佳實踐建議五、擴展方向一、核心思想解析 本系統通過遞歸算法實現了Markdown層級結構到PPTX架構圖的自動轉換,其核心設計思想包含兩個維度: 數據結構遞歸:將…

Python包管理器 uv替代conda?

有人問&#xff1a;python的包管理器uv可以替代conda嗎? 搞數據和算法的把conda當寶貝&#xff0c;其他的場景能替代。 Python的包管理器有很多&#xff0c;pip是原配&#xff0c;uv是后起之秀&#xff0c;conda則主打數據科學。 uv替代pip似乎只是時間問題了&#xff0c;它…

使用pnpm、vite搭建Phaserjs的開發環境

首先&#xff0c;確保你已經安裝了 Node.js 和 npm。然后按照以下步驟操作&#xff1a; 一、使用pnpm初始化一個新的 Vite 項目 pnpm create vite 輸入名字 選擇模板&#xff0c;這里我選擇Vanilla,也可以選擇其他的比如vue 選擇語言 項目新建完成 二、安裝相關依賴 進入項…

JS逆向案例—喜馬拉雅xm-sign詳情頁爬取

JS逆向案例——喜馬拉雅xm-sign詳情頁爬取 聲明網站流程分析總結 聲明 本文章中所有內容僅供學習交流&#xff0c;抓包內容、敏感網址、數據接口均已做脫敏處理&#xff0c;嚴禁用于商業用途和非法用途&#xff0c;否則由此產生的一切后果均與作者無關&#xff0c;若有侵權&am…

姜老師的MBTI課程:MBTI是可以轉變的

我們先來看內向和外向這條軸&#xff0c;I和E內向和外向受先天遺傳因素的影響還是比較大的&#xff0c;因為它事關到了你的硬件&#xff0c;也就是大腦的模型。但是我們在大五人格的排雷避坑和這套課程里面都強調了一個觀點&#xff0c;內向和外向各有優勢&#xff0c;也各有不…

進程同步:生產者-消費者 題目

正確答案&#xff1a; 問題類型&#xff1a; 經典生產者 - 消費者問題 同時涉及同步和互斥。 同步&#xff1a;生產者與消費者通過信號量協調生產 / 消費節奏&#xff08;如緩沖區滿時生產者等待&#xff0c;空時消費者等待&#xff09;。互斥&#xff1a;對共享緩沖區的訪問需…

吳恩達MCP課程(1):chat_bot

原課程代碼是用Anthropic寫的&#xff0c;下面代碼是用OpenAI改寫的&#xff0c;模型則用阿里巴巴的模型做測試 .env 文件為&#xff1a; OPENAI_API_KEYsk-xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx OPENAI_API_BASEhttps://dashscope.aliyuncs.com/compatible-mode…

Netty 實戰篇:手寫一個輕量級 RPC 框架原型

本文將基于前文實現的編解碼與心跳機制&#xff0c;構建一個簡單的 RPC 框架&#xff0c;包括請求封裝、響應解析、動態代理調用。為打造微服務通信基礎打下基礎。 一、什么是 RPC&#xff1f; RPC&#xff08;Remote Procedure Call&#xff0c;遠程過程調用&#xff09;允許…

邊緣計算新基建:iVX 輕量生成模塊的 ARM 架構突圍

一、引言 隨著工業 4.0 和物聯網的快速發展&#xff0c;邊緣計算作為連接云端與終端設備的關鍵技術&#xff0c;正成為推動數字化轉型的核心力量。在邊緣計算場景中&#xff0c;設備的實時性、低功耗和離線處理能力至關重要。ARM 架構憑借其低功耗、高能效的特點&#xff0c;成…

C# 基于 Windows 系統與 Visual Studio 2017 的 Messenger 消息傳遞機制詳解:發布-訂閱模式實現

&#x1f9d1; 博主簡介&#xff1a;CSDN博客專家、CSDN平臺優質創作者&#xff0c;高級開發工程師&#xff0c;數學專業&#xff0c;10年以上C/C, C#, Java等多種編程語言開發經驗&#xff0c;擁有高級工程師證書&#xff1b;擅長C/C、C#等開發語言&#xff0c;熟悉Java常用開…

js數據類型有哪些?它們有什么區別?

js數據類型共有8種,分別是undefined,null,boolean,number,string,Object,symbol,bigint symbol和bigint是es6中提出來的數據類型 symbol創建后獨一無二不可變的數據類型,它主要是為了解決出現全局變量沖突的問題 bigint 是一種數字類型的數據,它可以表示任意精度格式的整數,…

Vite打包優化實踐:從分包到性能提升

前言: ??????? 隨著前端應用功能的增加&#xff0c;項目的打包體積也會不斷膨脹&#xff0c;影響加載速度和用戶體驗。本文介紹了幾種常見的打包優化策略&#xff0c;通過Vite和相關插件&#xff0c;幫助減少項目體積、提升性能&#xff0c;優化加載速度。 rollup-plugi…

C++語法系列之模板進階

前言 本次會介紹一下非類型模板參數、模板的特化(特例化)和模板的可變參數&#xff0c;不是最開始學的模板 一、非類型模板參數 字面意思,比如&#xff1a; template<size_t N 10> 或者 template<class T,size_t N 10>比如&#xff1a;靜態棧就可以用到&#…

html5的響應式布局的方法示例詳解

以下是HTML5實現響應式布局的5種核心方法及代碼示例: 1. 媒體查詢(核心方案) /* 默認樣式(移動優先) */ .container {padding: 15px; }/* 中等屏幕(平板) */ @media (min-width: 768px) {.container {padding: 30px;max-width: 720px;} }/* 大屏幕(桌面) */ @media …

數字化轉型進階:精讀41頁華為數字化轉型實踐【附全文閱讀】

該文檔聚焦華為數字化轉型實踐&#xff0c;核心內容如下&#xff1a; 轉型本質與目標&#xff1a;數字化轉型是通過數字技術穿透業務&#xff0c;實現物理世界與數字世界的融合&#xff0c;目標是支撐主業成功、提升體驗與效率、探索模式創新。華為以 “平臺 服務” 為核心&am…

C++ - STL #什么是STL #STL的版本 #閉源開源 #STL的六大組件

文章目錄 前言 一、什么是STL 二、STL的版本 1、原始版本 2、P.J.版本 3、RW版本 4、SGI版本 三、閉源、開源 四、STL的六大組件 總結 前言 路漫漫其修遠兮&#xff0c;吾將上下而求索&#xff1b; 一、什么是STL STL(standard template libaray 標準模板庫)&#…

智慧康養護理:科技重塑老齡化社會的健康守護體系

在我國邁入深度老齡化社會的背景下&#xff0c;智慧康養護理作為融合科技與人文的創新模式&#xff0c;正成為提升老年人生活質量、減輕家庭照護壓力、促進健康老齡化的重要路徑。我們將從核心概念、關鍵技術、實際應用與未來趨勢四個維度&#xff0c;為您呈現智慧康養護理的全…

權威認證與質量保障:第三方檢測在科技成果鑒定測試中的核心作用

科技成果鑒定測試是衡量科研成果技術價值與應用潛力的關鍵環節&#xff0c;其核心目標在于通過科學驗證確保成果的可靠性、創新性和市場適配性。第三方檢測機構憑借其獨立性、專業性和權威性&#xff0c;成為科技成果鑒定測試的核心支撐主體。本文從測試流程、第三方檢測的價值…

Linux.docker.k8s基礎概念

1.Linux基本命令 cat 查看文件內容。 cd 進入目標目錄。 ll 查詢當前路勁下文件的詳細信息。 ls 查詢當前路勁下的文件。 touch 建立一個文件。 mkdir 建立一個文件夾。 rm 刪除文件或者目錄。 mv 移動目錄和重新命名文件。 unzip 解壓。 top 查看當前線程的信息。 find …

Python小白的蛻變之旅:從環境搭建到代碼規范(1/10)

摘要&#xff1a;全文圍繞 Python 編程展開&#xff0c;先是介紹如何搭建 Python 開發環境&#xff0c;推薦使用 Anaconda 和 VSCode&#xff0c;并詳細說明了二者的安裝及配置步驟&#xff0c;包括安裝 Anaconda、安裝 VSCode 并配置 Python 插件、選擇 Anaconda 的 Python 解…