直接與電腦溝通

更新於 發佈於 閱讀時間約 14 分鐘

1. 與電腦溝通之方法說明

1.1不須使用任何程式軟體工具,能與電腦溝通,使用Command line執行後,將依自己設定之條件,直接將結果選出,提供後續運用

1.2 Command line的運用

Command line是Command prompt (CMD),中文為「命令行」,

是使用者與電腦溝通的方法,意思是透過鍵盤輸入指令,電腦收到指示後,便能立即執行。

1.3如何開啟電腦中的command line?

在Window系統 [開始]中找到 搜尋search bar,打cmd或command prompt,就能成功進入command line了

 

2. 運用例說明

2.1 在某個檔案input file內有多筆紀錄record,尋找每筆紀錄record內,

某個項目(field)其值大於 80 的record選出

        即讀取資料檔案,檔名:CMD_jsonFile.txt (Input file) 

2.2  Txt file內容包含該機器之效能數據,如CPU 使用率,硬碟各個磁區

之使用量,使用率等,從CMD_jsonFile.txt內,判斷每筆record的資料,

若有硬碟磁區使用率 (field) 大於80%之record,則將該筆資料出力

 

2.3本實例之cmd 設計

set Jdate=
For /f "delims=; tokens=1,2*"  %%i
in ('findstr /r "\<Use_..:.[8-9][0-9]}\>  \<Use_..:.100}\>"  "CMD_jsonFile.txt" ')
do (
      set Jdate=%%j
      set WMI_detail=%%k
      CALL  :Judge_DATE   %%
     )        
         

[註解]

"delims=; tokens=1,2*"  %%i               

  delims=; à對象資料內,以 ; 作區隔

   tokens=1,2* à符合條件之對象資料,取出第一區隔項目,第二區隔項目,

           以及第二區隔項目以後之全部資料

   %%i : 第一區隔項目 以i 變數 運用

            第二區隔項目 以j 變數 運用

            第二區隔 項目以後之全部資料 以k 變數 運用

2.4本例出力取出之條件:

         若有使用率 > 80 , 或 100

          則取得三個變數之值 : i 機器名, j 資料日,k 詳細WMI資料                                   條件判斷之設計為

                "\<Use_..:.[8-9][0-9]}\>  \<Use_..:.100}\>"

2.5  入力 file CMD_jsonFile.txt 內有四筆record 內容如下:

XTW-DB1-01;Mon, 2023-08-07 09:50;{"CPU_%": 30, "MemTot_GB": 63.43, "MemUse_GB": 48.68};[{"Part": "C:", "TOT_GB": 200.0, "Use_GB": 46.35, "Use_%": 23}, {"Part": "D:", "TOT_GB": 357.04, "Use_GB": 20.26, "Use_%": 5}, {"Part": "Q:", "TOT_GB": 4.97, "Use_GB": 0.07, "Use_%": 1}, {"Part": "F:", "TOT_GB": 299.87, "Use_GB": 4.39, "Use_%": 1}, {"Part": "E:", "TOT_GB": 299.87, "Use_GB": 74.22, "Use_%": 24}]

XTW-SF-01;Wed, 2023-08-09 10:20;{"CPU_%": 25, "MemTot_GB": 16.0, "MemUse_GB": 3.92};[{"Part": "D:", "TOT_GB": 99.87, "Use_GB": 13.67, "Use_%": 13}, {"Part": "C:", "TOT_GB": 99.45, "Use_GB": 25.45, "Use_%": 25}]

XTW-BK03;Thu, 2023-08-10 08:00;{"CPU_%": 1, "MemTot_GB": 31.85, "MemUse_GB": 7.38};[{"Part": "C:", "TOT_GB": 150.0, "Use_GB": 25.87, "Use_%": 17}, {"Part": "D:", "TOT_GB": 200.0, "Use_GB": 30.21, "Use_%": 15}, {"Part": "E:", "TOT_GB": 1200.0, "Use_GB": 972.3, "Use_%": 81}, {"Part": "F:", "TOT_GB": 600.0, "Use_GB": 143.62, "Use_%": 23}, {"Part": "H:", "TOT_GB": 501.15, "Use_GB": 71.88, "Use_%": 14}, {"Part": "K:", "TOT_GB": 700.0, "Use_GB": 447.34, "Use_%": 63}, {"Part": "Y:", "TOT_GB": 4484.87, "Use_GB": 214.0, "Use_%": 4}]

XTW-DB2-01; Thu, 2023-08-10 09:50;{"CPU_%": 44, "MemTot_GB": 63.43, "MemUse_GB": 48.87};[{"Part": "C:", "TOT_GB": 200.0, "Use_GB": 46.39, "Use_%": 23}, {"Part": "D:", "TOT_GB": 357.04, "Use_GB": 20.31, "Use_%": 5}, {"Part": "Q:", "TOT_GB": 4.97, "Use_GB": 0.07, "Use_%": 1}, {"Part": "F:", "TOT_GB": 299.87, "Use_GB": 8.2, "Use_%": 2}, {"Part": "E:", "TOT_GB": 299.87, "Use_GB": 74.29, "Use_%": 24}]

3.實例之cmd 執行後,第三筆record被選出,選出資料如下

i 機器名: XTW-BK03 ,

j 資料日: Thu, 2023-08-10 08:00

k 詳細WMI資料如下:

 {"CPU_%": 1, "MemTot_GB": 31.85, "MemUse_GB": 7.38};[{"Part": "C:",

 …..  …

"TOT_GB": 4484.87, "Use_GB": 214.0, "Use_%": 4}]

 

 

4.實例使用兩個cmd 命令,說明如下:

4.1 FOR

   功能 : 對一組檔案中的每個檔案執行指定的命令。

 

 FOR %variable IN (set) DO 命令 [command-parameters]

  %variable  指定一個可以取代的參數。

  (set)      指定由一或多個檔案組成的檔案組。您可使用通配字元。

  command    指定命令來執行每一個檔案。

  command-parameters

             為所指定的命令指定變數或參數。

 

 FOR擴充命令格式:

FOR /F ["options"] %variable IN (file-set) DO command [command-parameters]

FOR /F ["options"] %variable IN ('string') DO command [command-parameters]

FOR /F ["options"] %variable IN (`command`) DO command [command-parameters]

 

4.2  findstr

    功能 : 在檔案中搜尋字串。

 

FINDSTR [/B] [/E] [/L] [/R] [/S] [/I] [/X] [/V] [/N] [/M] [/O] [/P] [/F:file]

        [/C:string] [/G:file] [/D:dir list] [/A:color attributes] [/OFF[LINE]]

        strings [[drive:][path]filename[ ...]]

 

  /B        如果是在行的開端,則符合類型。

  /E        如果是在行的尾端,則符合類型。

  /L        逐字使用搜尋字串。

  /R        使用搜尋字串為一般表示式。

  /S        在現存目錄及所有的子目錄中搜尋符合的檔案。

  /I        指定搜尋不區分大小寫。

  /X        列印完全符合的行數。

  /V        只列印不含相符字串的行數。

  /N        列印每一行符合的行數前的行編號。

  /M        只列印包含相符字串的檔案的檔案名稱。

  /O        列印每一個相符行之前的字元位移。

  /P        跳過沒有可列印字元的檔案。

  /OFF[LINE] 不要跳過有離線屬性設定的檔案。

  /A:attr    以兩個十六進位數字指定色彩屬性。請參閱 "color /?"。

  /F:file   從指定的檔案讀取檔案清單 (/ 代表主控台)。

  /C:string 使用特定的字串作為逐字搜尋的字串。

  /G:file   從指定的檔案取得搜尋字串 (/ 代表主控台)。

  /D:dir    搜尋以分號隔開的目錄清單。

  strings   要搜尋的文字。

  [drive:][path]filename  指定要搜尋的一個或多個檔案。

 

除非引數的字首有 /C,否則請以空格將多重搜尋字串分開。

例如,'FINDSTR "hello there" x.y' 將會在檔案 x.y 中

搜尋 "hello",或 "there"。'FINDSTR /C:"hello there" x.y'

將會在檔案x.y 中搜尋 "hello there"。

 5.  擴充運用:

  5.1日常使用的檔案,可依自己需要,設定條件選出,例如

       上班打卡時間遲到者之選取

       人事資料內年齡大於60者選出

       各科成績分數小於60者選出

       公司員工住所在”高雄市”者選出

        ……

5.2 input file 若是Excel 檔,可先轉成csv or txt檔之格式,一樣可使用上述功能

5.3 cmd 設計完成後,再作成bat執行檔,

於Windows工作排程器(task Scheduler)設定執行,讓程式依照排程自動執行,將選出之資料內容,利用mail or LINE等方法,即時自動送出給擔當,以便可即時確認對應

------------------recorded by linct ------------------

留言
avatar-img
留言分享你的想法!
avatar-img
linct的沙龍
64會員
185內容數
樂趣體驗紀錄,沙龍房間有歌唱,生活,科技
linct的沙龍的其他內容
2025/05/01
ECCEL工作表內各欄位數值或件數之合計,利用以下4個函數來自動算出,如下說明 1.【COUNT 函數 】 2.【COUNTA 函數 】 3.【COUNT IF函數 】 4.【COUNTIFS 函數 】
Thumbnail
2025/05/01
ECCEL工作表內各欄位數值或件數之合計,利用以下4個函數來自動算出,如下說明 1.【COUNT 函數 】 2.【COUNTA 函數 】 3.【COUNT IF函數 】 4.【COUNTIFS 函數 】
Thumbnail
2025/03/31
比爾·蓋茲於1999年出版的《數位神經系統》一書,至今仍具有參考價值。本文探討該書的核心概念,如何在當今的科技環境下應用數位神經系統,並提出一些需要調整的部分。
Thumbnail
2025/03/31
比爾·蓋茲於1999年出版的《數位神經系統》一書,至今仍具有參考價值。本文探討該書的核心概念,如何在當今的科技環境下應用數位神經系統,並提出一些需要調整的部分。
Thumbnail
2025/01/26
此程式利用批次檔(bat)結合vbscript,自動篩選Windows事件紀錄,並產生Excel報表,方便管理人員統計與分析系統事件。
Thumbnail
2025/01/26
此程式利用批次檔(bat)結合vbscript,自動篩選Windows事件紀錄,並產生Excel報表,方便管理人員統計與分析系統事件。
Thumbnail
看更多
你可能也想看
Thumbnail
「欸!這是在哪裡買的?求連結 🥺」 誰叫你太有品味,一發就讓大家跟著剁手手? 讓你回購再回購的生活好物,是時候該介紹出場了吧! 「開箱你的美好生活」現正召喚各路好物的開箱使者 🤩
Thumbnail
「欸!這是在哪裡買的?求連結 🥺」 誰叫你太有品味,一發就讓大家跟著剁手手? 讓你回購再回購的生活好物,是時候該介紹出場了吧! 「開箱你的美好生活」現正召喚各路好物的開箱使者 🤩
Thumbnail
歡迎來到我們的Windows教學!在這裡,你將學習如何有效使用Windows操作系統。我們將探索各種基本操作,如文件管理、桌面設置、程式安裝和系統設置。無論你是新手還是希望深入了解Windows的使用者,我們的教學內容都能夠幫助你提升操作技能,使你在日常使用和工作中更加流暢和高效。立即加入我們,開啟
Thumbnail
歡迎來到我們的Windows教學!在這裡,你將學習如何有效使用Windows操作系統。我們將探索各種基本操作,如文件管理、桌面設置、程式安裝和系統設置。無論你是新手還是希望深入了解Windows的使用者,我們的教學內容都能夠幫助你提升操作技能,使你在日常使用和工作中更加流暢和高效。立即加入我們,開啟
Thumbnail
本文詳細介紹Windows cmd指令的應用,並提供了例說明及追加說明,用戶可以學習如何使用cmd指令對檔案進行處理、選取所需的內容,以及擴展運用到其他類型的檔案,最後還介紹了cmd設計完成後的應用和自動化執行方式。
Thumbnail
本文詳細介紹Windows cmd指令的應用,並提供了例說明及追加說明,用戶可以學習如何使用cmd指令對檔案進行處理、選取所需的內容,以及擴展運用到其他類型的檔案,最後還介紹了cmd設計完成後的應用和自動化執行方式。
Thumbnail
設計程式來讀取欲傳送訊息之參數txt檔案,再利用程式自動傳出訊息至LINE群組。能簡易使用於任何場合。
Thumbnail
設計程式來讀取欲傳送訊息之參數txt檔案,再利用程式自動傳出訊息至LINE群組。能簡易使用於任何場合。
Thumbnail
欲傳送之內容,由使用者輸入於文字檔內,執行本執行檔後,指定之LINE群組全員,將會收到推播訊息
Thumbnail
欲傳送之內容,由使用者輸入於文字檔內,執行本執行檔後,指定之LINE群組全員,將會收到推播訊息
Thumbnail
上回說明的手動下指令,傳出訊息。為了節省手動輸入之動作,將欲執行的curl指令內容,事先作成執行檔。當需要傳送訊息時,只要按兩下執行檔,便可立刻傳出訊息至LINE群組內之全員 2. 說明 2.1 因每次要傳送內容不同,將這些會變動的訊息資料,輸入後保存 於bat執行檔內
Thumbnail
上回說明的手動下指令,傳出訊息。為了節省手動輸入之動作,將欲執行的curl指令內容,事先作成執行檔。當需要傳送訊息時,只要按兩下執行檔,便可立刻傳出訊息至LINE群組內之全員 2. 說明 2.1 因每次要傳送內容不同,將這些會變動的訊息資料,輸入後保存 於bat執行檔內
Thumbnail
如何將LINE訊息自動傳出,利用curl工具
Thumbnail
如何將LINE訊息自動傳出,利用curl工具
追蹤感興趣的內容從 Google News 追蹤更多 vocus 的最新精選內容追蹤 Google News