中午起来没事儿写着玩儿,实在没时间整理代码,思路不知道弯不弯曲,但至少实现了需求。
#include <Array.au3>
#include <File.au3>
$aFileArray = _FileListToArray(@ScriptDir & '\test')
_ArrayDisplay($aFileArray)
; 冒泡
For $i = 1 To $aFileArray[0] - 1
For $j = 1 To $aFileArray[0] - 1
;~ MsgBox(0, $aFileArray[$j] & '--' & $aFileArray[$j + 1], __CompareByUnicode($aFileArray[$j], $aFileArray[$j + 1]))
If (__CompareByUnicode($aFileArray[$j], $aFileArray[$j + 1]) == -1) Then
Dim $tmpSwap = $aFileArray[$j]
$aFileArray[$j] = $aFileArray[$j + 1]
$aFileArray[$j + 1] = $tmpSwap
EndIf
Next
Next
_ArrayDisplay($aFileArray)
; 根据字符顺序做对比
Func __CompareByUnicode($sSrc, $sDest)
Local $nSrcLength = StringLen($sSrc)
Local $nDestLength = StringLen($sDest)
; 先对比长度是否一致
If ($nSrcLength > $nDestLength) Then
Return -1
ElseIf ($nSrcLength < $nDestLength) Then
Return 1
Else
; 在对比字符顺序)
For $i = 1 To $nSrcLength
Local $cSrcChar = StringMid($sSrc, $i, 1)
Local $cDestChar = StringMid($sDest, $i, 1)
If (AscW($cSrcChar) > AscW($cDestChar)) Then
Return -1
ElseIf (AscW($cSrcChar) < AscW($cDestChar)) Then
Return 1
Else
ContinueLoop
EndIf
Next
EndIf
Return 0
EndFunc
|