学习Windows(BAT)、Linux(Shell)编程,并分别写一个脚本文件解决自己的一个问题
delete:
@echo off 
echo Press any key to delete this file.
pause 
del %0
ip:
@echo off 
color a 
Title 端口-进程查询 
setlocal enabledelayedexpansion  
echo 本机开放的端口及使用该端口的进程 
echo ------------------------------------ 
echo 端口号 进程名称 
ECHO TCP协议: 
::利用netstat命令找出使用TCP协议通信的端口,并将结果分割; 
::将第二个参数(IP加端口)传给%%i,第五个参数(PID号)传给%%j; 
for /F "usebackq skip=4 tokens=2,5" %%i in (`"netstat -ano -p TCP"`) do ( 
call :Assoc %%i TCP %%j 
echo !TCP_Port! !TCP_Proc_Name! 
) 
ECHO UDP协议: 
for /F "usebackq skip=4 tokens=2,4" %%i in (`"netstat -ano -p UDP"`) do ( 
call :Assoc %%i UDP %%j 
echo !UDP_Port! !UDP_Proc_Name! 
) 
echo 按任意键退出 
pause>nul 
:Assoc 
::对%1(第一个参数)进行分割,将第二个参数传给%%e。在本程序中,%1即为上面的%%i(形式为:IP:端口号) 
for /F "tokens=2 delims=:" %%e in ("%1") do ( 
set %2_Port=%%e 
) 
:: 查询PID等于%3(第三个参数)的进程,并将结果传给变量?_Proc_Name,?代表UDP或者TCP; 
for /F "skip=2 usebackq delims=, tokens=1" %%a in (`"Tasklist /FI "PID eq %3" /FO CSV"`) do ( 
::%%~a表示去掉%%a外面的引号,因为上述命令的结果是用括号括起来的。 
set %2_Proc_Name=%%~a 
) 
sort:
#/bin/bash
a=`expr $# + 1`
temp=
for((i=1;i<$a;i++))
{
 b[$i]=$1
 shift 1
}
for((i=1;i<$a;i++))
{
 for((j=i;j<$a;j++))
 {
  x=${b[$i]}
  if test $x -ge ${b[$j]}
  then 
   temp=${b[$i]}
   b[i]=${b[$j]}
   b[j]=$temp
  fi
 }
}
for((k=1;k<$a;k++))
{
 echo -n ${b[$k]} " "
}
echo
 
                    
                
 
                
            
         浙公网安备 33010602011771号
浙公网安备 33010602011771号