@@ -41,7 +41,7 @@ https://github.com/XIU2/CloudflareSpeedTest
4141 -url https://cf.xiu2.xyz/Github/CloudflareSpeedTest.png
4242 下载测速地址;用来下载测速的 Cloudflare CDN 文件地址,如地址含有空格请加上引号;
4343 -tl 200
44- 平均延迟上限;只输出低于指定平均延迟的 IP,与下载速度下限搭配使用 ;(默认 9999.00 ms)
44+ 平均延迟上限;只输出低于指定平均延迟的 IP,可单独使用也可搭配下载速度下限 ;(默认 9999.00 ms)
4545 -sl 5
4646 下载速度下限;只输出高于指定下载速度的 IP,凑够指定数量 [-dn] 才会停止测速;(默认 0.00 MB/s)
4747 -p 20
@@ -68,7 +68,7 @@ https://github.com/XIU2/CloudflareSpeedTest
6868 flag .IntVar (& downloadTestCount , "dn" , 20 , "下载测速数量" )
6969 flag .IntVar (& downloadSecond , "dt" , 10 , "下载测速时间" )
7070 flag .StringVar (& url , "url" , "https://cf.xiu2.xyz/Github/CloudflareSpeedTest.png" , "下载测速地址" )
71- flag .Float64Var (& timeLimit , "tl" , 9999 , "延迟时间上限 " )
71+ flag .Float64Var (& timeLimit , "tl" , 9999 , "平均延迟上限 " )
7272 flag .Float64Var (& speedLimit , "sl" , 0 , "下载速度下限" )
7373 flag .IntVar (& printResultNum , "p" , 20 , "显示结果数量" )
7474 flag .BoolVar (& disableDownload , "dd" , false , "禁用下载测速" )
@@ -136,14 +136,15 @@ func main() {
136136 var wg sync.WaitGroup
137137 var mu sync.Mutex
138138 var data = make ([]CloudflareIPData , 0 )
139- var data_2 = make ([]CloudflareIPData , 0 )
139+ var data2 = make ([]CloudflareIPData , 0 )
140140 downloadTestTime = time .Duration (downloadSecond ) * time .Second
141141
142+ // 开始延迟测速
142143 fmt .Println ("# XIU2/CloudflareSpeedTest " + version + "\n " )
143- if ipv6Mode {
144- fmt .Println ("开始延迟测速(模式:TCP IPv6,端口:" + strconv .Itoa (tcpPort ) + "):" )
144+ if ipv6Mode { // IPv6 模式判断
145+ fmt .Println ("开始延迟测速(模式:TCP IPv6,端口:" + strconv .Itoa (tcpPort ) + ",平均延迟上限:" + fmt . Sprintf ( "%.2f" , timeLimit ) + " ms ):" )
145146 } else {
146- fmt .Println ("开始延迟测速(模式:TCP IPv4,端口:" + strconv .Itoa (tcpPort ) + "):" )
147+ fmt .Println ("开始延迟测速(模式:TCP IPv4,端口:" + strconv .Itoa (tcpPort ) + ",平均延迟上限:" + fmt . Sprintf ( "%.2f" , timeLimit ) + " ms ):" )
147148 }
148149 control := make (chan bool , pingRoutine )
149150 for _ , ip := range ips {
@@ -155,54 +156,61 @@ func main() {
155156 wg .Wait ()
156157 bar .Finish ()
157158
158- sort .Sort (CloudflareIPDataSet (data )) // 排序
159+ sort .Sort (CloudflareIPDataSet (data )) // 排序(按延迟,从低到高,不同丢包率会分开单独按延迟和丢包率排序)
159160
160- // 下载测速
161+ // 延迟测速完毕后,以 [平均延迟上限] 条件过滤结果
162+ if timeLimit < 9999 && timeLimit > 0 {
163+ for i := 0 ; i < len (data ); i ++ {
164+ if float64 (data [i ].pingTime ) <= timeLimit {
165+ data2 = append (data2 , data [i ]) // 延迟满足条件时,添加到新数组中
166+ } else {
167+ break
168+ }
169+ }
170+ data = data2
171+ data2 = []CloudflareIPData {}
172+ }
173+
174+ // 开始下载测速
161175 if ! disableDownload { // 如果禁用下载测速就跳过
162- if len (data ) > 0 { // IP数组长度(IP数量) 大于 0 时继续
163- if len (data ) < downloadTestCount { // 如果IP数组长度(IP数量) 小于 下载测速次数,则次数改为IP数
164- //fmt.Println("\n[信息] IP 数量小于下载测速次数(" + strconv.Itoa(downloadTestCount) + " < " + strconv.Itoa(len(data)) + "),下载测速次数改为IP数。\n")
176+ if len (data ) > 0 { // IP数组长度(IP数量) 大于 0 时才会继续下载测速
177+ if len (data ) < downloadTestCount { // 如果IP数组长度(IP数量) 小于下载测速数量(-dn),则次数修正为IP数
165178 downloadTestCount = len (data )
166179 }
167- var downloadTestCount_2 int // 临时的下载测速次数
168- if timeLimit == 9999 && speedLimit == 0 {
169- downloadTestCount_2 = downloadTestCount // 如果没有指定条件,则临时变量为下载测速次数
170- } else if timeLimit > 0 || speedLimit >= 0 {
171- downloadTestCount_2 = len ( data ) // 如果指定了任意一个条件,则临时变量改为总数量
180+ var downloadTestCount2 int // 临时的下载测速次数,即实际的下载测速数量
181+ if speedLimit > 0 {
182+ downloadTestCount2 = len ( data ) // 如果指定了 [下载速度下限] 条件,则临时变量改为总数量(即一直测速下去,直到凑够下载测速数量 -dn)
183+ } else {
184+ downloadTestCount2 = downloadTestCount // 如果没有指定 [下载速度下限] 条件,则临时变量为下载测速数量(-dn)
172185 }
173- fmt .Println ("开始下载测速(延迟时间上限 :" + fmt .Sprintf ("%.2f" , timeLimit ) + " ms,下载速度下限 :" + fmt . Sprintf ( "%.2f" , speedLimit ) + " MB/s ):" )
186+ fmt .Println ("开始下载测速(下载速度下限 :" + fmt .Sprintf ("%.2f" , speedLimit ) + " MB/s,下载测速数量 :" + strconv . Itoa ( downloadTestCount ) + ",下载测速队列:" + strconv . Itoa ( downloadTestCount2 ) + "):" )
174187 bar = pb .Simple .Start (downloadTestCount )
175- for i := 0 ; i < downloadTestCount_2 ; i ++ {
188+ for i := 0 ; i < downloadTestCount2 ; i ++ {
176189 _ , speed := DownloadSpeedHandler (data [i ].ip )
177190 data [i ].downloadSpeed = speed
178- if float64 (data [i ].pingTime ) <= timeLimit && float64 (speed )/ 1024 / 1024 >= speedLimit {
179- data_2 = append (data_2 , data [i ]) // 延迟和速度均满足条件时,添加到新数组中
191+ // 在每个 IP 下载测速后,以 [下载速度下限] 条件过滤结果
192+ if float64 (speed )/ 1024 / 1024 >= speedLimit {
193+ data2 = append (data2 , data [i ]) // 高于下载速度下限时,添加到新数组中
180194 bar .Add (1 )
181- if len (data_2 ) == downloadTestCount { // 满足条件的 IP =下载测速次数,则跳出循环
195+ if len (data2 ) == downloadTestCount { // 凑够满足条件的 IP 时(下载测速数量 -dn),就跳出循环
182196 break
183197 }
184- } else if float64 (data [i ].pingTime ) > timeLimit {
185- break
186198 }
187199 }
188200 bar .Finish ()
189201 } else {
190- fmt .Println ("\n [信息] IP数量为 0,跳过下载测速。" )
202+ fmt .Println ("\n [信息] 延迟测速结果 IP 数量为 0,跳过下载测速。" )
191203 }
192204 }
193205
194- if len (data_2 ) > 0 { // 如果该数组有内容,说明进行过指定条件的下载测速
195- sort .Sort (CloudflareIPDataSetD (data_2 )) // 排序
196- if outputFile != "" {
197- ExportCsv (outputFile , data_2 ) // 输出结果到文件(指定延迟时间或下载速度的)
198- }
199- printResult (data_2 ) // 显示最快结果(指定延迟时间或下载速度的)
200- } else {
201- if outputFile != "" {
202- ExportCsv (outputFile , data ) // 输出结果到文件
203- }
204- printResult (data ) // 显示最快结果
206+ if len (data2 ) > 0 { // 如果该数组有内容,说明指定了 [下载测速下限] 条件,且最少有 1 个满足条件的 IP
207+ data = data2
208+ }
209+ sort .Sort (CloudflareIPDataSetD (data )) // 排序(按下载速度,从高到低)
210+ if outputFile != "" {
211+ ExportCsv (outputFile , data ) // 输出结果到文件
205212 }
213+ printResult (data ) // 显示最快结果
206214}
207215
208216// 显示最快结果
@@ -212,7 +220,6 @@ func printResult(data []CloudflareIPData) {
212220 dateString := convertToString (data ) // 转为多维数组 [][]String
213221 if len (dateString ) > 0 { // IP数组长度(IP数量) 大于 0 时继续
214222 if len (dateString ) < printResultNum { // 如果IP数组长度(IP数量) 小于 打印次数,则次数改为IP数量
215- //fmt.Println("\n[信息] IP 数量小于显示结果数量(" + strconv.Itoa(printResultNum) + " < " + strconv.Itoa(len(dateString)) + "),显示结果数量改为IP数量。\n")
216223 printResultNum = len (dateString )
217224 }
218225 if ipv6Mode { // IPv6 太长了,所以需要调整一下间隔
@@ -231,7 +238,7 @@ func printResult(data []CloudflareIPData) {
231238 fmt .Println ("\n 发现新版本 [" + versionNew + "]!请前往 [https://github.com/XIU2/CloudflareSpeedTest] 更新!" )
232239 }
233240
234- if sysType == "windows" { // 如果是 Windows 系统,则需要按下 回车键 或 Ctrl+C 退出
241+ if sysType == "windows" { // 如果是 Windows 系统,则需要按下 回车键 或 Ctrl+C 退出(避免通过双击运行时,测速完毕后直接关闭)
235242 if outputFile != "" {
236243 fmt .Printf ("\n 完整测速结果已写入 %v 文件,请使用记事本/表格软件查看。\n 按下 回车键 或 Ctrl+C 退出。" , outputFile )
237244 } else {
@@ -245,7 +252,7 @@ func printResult(data []CloudflareIPData) {
245252 }
246253 }
247254 } else {
248- fmt .Println ("\n [信息] IP数量为 0,跳过输出结果。" )
255+ fmt .Println ("\n [信息] 完整测速结果 IP 数量为 0,跳过输出结果。" )
249256 }
250257 } else {
251258 fmt .Println ("\n 完整测速结果已写入 " + outputFile + " 文件,请使用记事本/表格软件查看。" )
0 commit comments