Explorar o código

新增 指定延迟时间上限、下载速度下限条件

xiu2 %!s(int64=5) %!d(string=hai) anos
pai
achega
40b22f660a
Modificáronse 2 ficheiros con 70 adicións e 22 borrados
  1. 23 12
      README.md
  2. 47 10
      main.go

+ 23 - 12
README.md

@@ -38,6 +38,7 @@ IP 地址           已发送  已接收  丢包率  平均延迟  下载速度
 104.22.78.104     4       4       0.00    146.75    13.00
 104.22.69.208     4       4       0.00    147.00    19.07
 104.27.194.10     4       4       0.00    148.02    21.05
+...
 ```
 
 完整结果保存在当前目录下的 `result.csv` 文件中,用**记事本/表格软件**打开,排序为**延迟由低到高**,分别是:  
@@ -56,8 +57,6 @@ IP 地址, 已发送, 已接收, 丢包率, 平均延迟, 下载速度 (MB/s)
 
 直接双击运行使用的是默认参数,如果想要测试速度更快、测试结果更全面,可以自定义参数。  
 
-> **提示:Linux 系统**只需要把下面命令中的 **.exe 删除**即可通用。  
-
 ``` cmd
 C:\>CloudflareST.exe -h
 
@@ -78,6 +77,10 @@ https://github.com/XIU2/CloudflareSpeedTest
         下载测速时间;单个 IP 测速最长时间,单位:秒;(默认 5)
     -url https://cf.xiu2.xyz/Github/CloudflareSpeedTest.png
         下载测速地址;用来 Cloudflare CDN 测速的文件地址,如含有空格请加上引号;
+    -tl 200
+        延迟时间上限;只输出指定延迟时间以下的结果,数量为 -dn 参数的值,单位:ms;
+    -sl 5
+        下载速度下限;只输出指定下载速度以上的结果,数量为 -dn 参数的值,单位:MB/s;
     -p 20
         显示结果数量;测速后直接显示指定数量的结果,为 0 时不显示结果直接退出;(默认 20)
     -f ip.txt
@@ -97,27 +100,35 @@ https://github.com/XIU2/CloudflareSpeedTest
 ### 使用示例
 
 在 CMD 中运行,或者把启动参数添加到快捷方式中。  
-> **注意:** 不需要加上所有参数,按需选择,参数前后顺序随意。  
 > **提示: Linux 系统**只需要把下面命令中的 **.exe 删除**即可通用。  
 
-``` cmd
-# 命令行示例
-CloudflareST.exe -n 500 -t 4 -dn 20 -dt 5
+``` bash
+# 注意:各参数均有默认值,只有不使用默认值时,才需要手动指定参数的值(按需选择),参数不分前后顺序。  
+# 提示: Linux 系统只需要把下面命令中的 .exe 删除即可通用。  
 
 # 指定 IP数据文件,不显示结果直接退出(-p 值为 0)
-CloudflareST.exe -n 500 -t 4 -dn 20 -dt 5 -p 0 -f "ip.txt" -dd
+CloudflareST.exe -p 0 -f ip.txt -dd
 
-# 指定 IP数据文件,不输出结果到文件,直接显示结果(-p 值为 20 条)
-CloudflareST.exe -n 500 -t 4 -dn 20 -dt 5 -p 20 -f "ip.txt" -o " " -dd
+# 指定 IP数据文件,不输出结果到文件,直接显示结果(-p 值为 10 条)
+CloudflareST.exe -p 10 -f ip.txt -o " " -dd
 
 # 指定 IP数据文件 及 输出结果到文件(相对路径,即当前目录下,如果包含空格请加上引号)
-CloudflareST.exe -n 500 -t 4 -dn 20 -dt 5 -f ip.txt -o result.csv -dd
+CloudflareST.exe -f ip.txt -o result.csv -dd
 
 # 指定 IP数据文件 及 输出结果到文件(绝对路径,即 C:\abc\ 目录下,如果包含空格请加上引号)
-CloudflareST.exe -n 500 -t 4 -dn 20 -dt 5 -f C:\abc\ip.txt -o C:\abc\result.csv -dd
+CloudflareST.exe -f C:\abc\ip.txt -o C:\abc\result.csv -dd
 
 # 指定下载测速地址(要求:可以直接下载的文件、文件大小超过 200MB、网站用的是 Cloudflare CDN),如果包含空格请加上引号
-CloudflareST.exe -n 500 -t 4 -dn 20 -dt 5 -url https://cf.xiu2.xyz/Github/CloudflareSpeedTest.png
+CloudflareST.exe -url https://cf.xiu2.xyz/Github/CloudflareSpeedTest.png
+
+# 指定测速条件,延迟时间上限:200 ms,下载速度下限:0 MB/s,数量:10 个(只有同时满足三个条件时才会停止测速)
+CloudflareST.exe -tl 200 -dn 10
+
+# 指定测速条件,延迟时间上限:0 ms,下载速度下限:5 MB/s,数量:10 个(只有同时满足三个条件时才会停止测速)
+CloudflareST.exe -sl 5 -dn 10
+
+# 指定测速条件,延迟时间上限:200 ms,下载速度下限:5 MB/s,数量:10 个(只有同时满足三个条件时才会停止测速)
+CloudflareST.exe -tl 200 -sl 5 -dn 10
 ```
 
 ``` cmd

+ 47 - 10
main.go

@@ -18,6 +18,8 @@ var tcpPort int
 var ipFile string
 var outputFile string
 var printResultNum int
+var timeLimit int
+var speedLimit int
 
 func init() {
 	var downloadSecond int64
@@ -40,6 +42,10 @@ https://github.com/XIU2/CloudflareSpeedTest
         下载测速时间;单个 IP 测速最长时间,单位:秒;(默认 5)
     -url https://cf.xiu2.xyz/Github/CloudflareSpeedTest.png
         下载测速地址;用来 Cloudflare CDN 测速的文件地址,如含有空格请加上引号;
+    -tl 200
+        延迟时间上限;只输出指定延迟时间以下的结果,数量为 -dn 参数的值,单位:ms;
+    -sl 5
+        下载速度下限;只输出指定下载速度以上的结果,数量为 -dn 参数的值,单位:MB/s;
     -p 20
         显示结果数量;测速后直接显示指定数量的结果,值为 0 时不显示结果直接退出;(默认 20)
     -f ip.txt
@@ -59,6 +65,8 @@ https://github.com/XIU2/CloudflareSpeedTest
 	flag.IntVar(&downloadTestCount, "dn", 20, "下载测速数量")
 	flag.Int64Var(&downloadSecond, "dt", 5, "下载测速时间")
 	flag.StringVar(&url, "url", "https://cf.xiu2.xyz/Github/CloudflareSpeedTest.png", "下载测速地址")
+	flag.IntVar(&timeLimit, "tl", 0, "延迟时间上限")
+	flag.IntVar(&speedLimit, "sl", 0, "下载速度下限")
 	flag.IntVar(&printResultNum, "p", 20, "显示结果数量")
 	flag.BoolVar(&disableDownload, "dd", false, "禁用下载测速")
 	flag.StringVar(&ipFile, "f", "ip.txt", "IP 数据文件")
@@ -91,6 +99,12 @@ https://github.com/XIU2/CloudflareSpeedTest
 	if url == "" {
 		url = "https://cf.xiu2.xyz/Github/CloudflareSpeedTest.png"
 	}
+	if timeLimit <= 0 {
+		timeLimit = 9999
+	}
+	if speedLimit < 0 {
+		speedLimit = 0
+	}
 	if printResultNum < 0 {
 		printResultNum = 20
 	}
@@ -111,6 +125,7 @@ func main() {
 	var wg sync.WaitGroup
 	var mu sync.Mutex
 	var data = make([]CloudflareIPData, 0)
+	var data_2 = make([]CloudflareIPData, 0)
 
 	fmt.Println("# XIU2/CloudflareSpeedTest " + version + "\n")
 	fmt.Println("开始延迟测速(模式:TCP,端口:" + strconv.Itoa(tcpPort) + "):")
@@ -130,15 +145,31 @@ func main() {
 	if !disableDownload { // 如果禁用下载测速就跳过
 		if len(data) > 0 { // IP数组长度(IP数量) 大于 0 时继续
 			if len(data) < downloadTestCount { // 如果IP数组长度(IP数量) 小于 下载测速次数,则次数改为IP数
+				//fmt.Println("\n[信息] IP 数量小于下载测速次数(" + strconv.Itoa(downloadTestCount) + " < " + strconv.Itoa(len(data)) + "),下载测速次数改为IP数。\n")
 				downloadTestCount = len(data)
-				fmt.Println("\n[信息] IP数量小于下载测速次数,下载测速次数改为IP数。\n")
+
+			}
+			var downloadTestCount_2 int // 临时的下载测速次数
+			if timeLimit == 9999 && speedLimit == 0 {
+				downloadTestCount_2 = downloadTestCount // 如果没有指定条件,则临时的下载次数变量为下载测速次数
+				fmt.Println("开始下载测速:")
+			} else if timeLimit > 0 || speedLimit >= 0 {
+				downloadTestCount_2 = len(data) // 如果指定了任意一个条件,则临时的下载次数变量改为总数量
+				fmt.Println("开始下载测速(延迟时间上限:" + strconv.Itoa(timeLimit) + " ms,下载速度下限:" + strconv.Itoa(speedLimit) + " MB/s):")
 			}
-			bar = pb.Simple.Start(downloadTestCount)
-			fmt.Println("开始下载测速:")
-			for i := 0; i < downloadTestCount; i++ {
+			bar = pb.Simple.Start(downloadTestCount_2)
+			for i := 0; i < downloadTestCount_2; i++ {
 				_, speed := DownloadSpeedHandler(data[i].ip)
 				data[i].downloadSpeed = speed
 				bar.Add(1)
+				if int(data[i].pingTime) <= timeLimit && int(float64(speed)/1024/1024) >= speedLimit {
+					data_2 = append(data_2, data[i])      // 延迟和速度均满足条件时,添加到新数组中
+					if len(data_2) == downloadTestCount { // 满足条件的 IP =下载测速次数,则跳出循环
+						break
+					}
+				} else if int(data[i].pingTime) > timeLimit {
+					break
+				}
 			}
 			bar.Finish()
 		} else {
@@ -146,11 +177,17 @@ func main() {
 		}
 	}
 
-	if outputFile != "" {
-		ExportCsv(outputFile, data) // 输出结果到文件
+	if len(data_2) > 0 { // 如果该数字有内容,说明进行过指定条件的下载测速
+		if outputFile != "" {
+			ExportCsv(outputFile, data_2) // 输出结果到文件(指定延迟时间或下载速度的)
+		}
+		printResult(data_2) // 显示最快结果(指定延迟时间或下载速度的)
+	} else {
+		if outputFile != "" {
+			ExportCsv(outputFile, data) // 输出结果到文件
+		}
+		printResult(data) // 显示最快结果
 	}
-
-	printResult(data) // 显示最快结果
 }
 
 // 显示最快结果
@@ -159,15 +196,15 @@ func printResult(data []CloudflareIPData) {
 		dateString := convertToString(data) // 转为多维数组 [][]String
 		if len(dateString) > 0 {            // IP数组长度(IP数量) 大于 0 时继续
 			if len(dateString) < printResultNum { // 如果IP数组长度(IP数量) 小于  打印次数,则次数改为IP数量
+				//fmt.Println("\n[信息] IP 数量小于显示结果数量(" + strconv.Itoa(printResultNum) + " < " + strconv.Itoa(len(dateString)) + "),显示结果数量改为IP数量。\n")
 				printResultNum = len(dateString)
-				fmt.Println("\n[信息] IP数量小于显示结果数量,显示结果数量改为IP数量。\n")
 			}
 			fmt.Printf("%-16s%-5s%-5s%-5s%-6s%-11s\n", "IP 地址", "已发送", "已接收", "丢包率", "平均延迟", "下载速度 (MB/s)")
 			for i := 0; i < printResultNum; i++ {
 				fmt.Printf("%-18s%-8s%-8s%-8s%-10s%-15s\n", ipPadding(dateString[i][0]), dateString[i][1], dateString[i][2], dateString[i][3], dateString[i][4], dateString[i][5])
 			}
 			if outputFile != "" {
-				fmt.Printf("\n完整测速结果已写入 %v 文件,请使用记事本/表格软件查看。按下 回车键 或 Ctrl+C 退出。", outputFile)
+				fmt.Printf("\n完整测速结果已写入 %v 文件,请使用记事本/表格软件查看。\n按下 回车键 或 Ctrl+C 退出。", outputFile)
 			} else {
 				fmt.Printf("\n请按 回车键 或 Ctrl+C 退出。")
 			}