批处理文件从目录中随机选择?

时间:2015-08-21 06:03:32

标签: batch-file vbscript

我正在计算机上使用人工智能,我有一个简单的命令,我说"给我一首快乐的歌"。我想要做的是触发一个批处理文件,该文件将转到我有各种欢乐歌曲的文件中。

我不知道批量的大量知识,特别是涉及到randoms时。我只是想要它所以它将从文件中随机选择歌曲。这会像.vbs一样好吗?除了如何制作文件之外,我什么都不知道。如果它是批次并且您能够帮助我,那么如果您能向我解释一下这一点,我将非常感激,所以我希望能够自己做更多这些。

保存mp3的文件是C:\ Users \ ptldk \ Documents \ Batch \ Batch Support \ Random Happy Music播放列表

谢谢

3 个答案:

答案 0 :(得分:2)

如果要浏览文件夹和文件,请考虑使用for循环和forfiles命令。你需要做的是:

1)循环浏览Music_PATH并仅搜索扩展名为.mp3的文件。

2)创建一个数组(即使批处理没有此功能,但我们可以手动完成),并为其分配文件名。 %%~nxa删除引号并在文件名末尾添加扩展名。

3)由于%random%返回0-32767之间的值,并且我们不需要这么大的值,因此%random% %% VALUE(e.g: 10)将返回0-9之间的值。这很好,因为我们正在玩数组,值0将是数组的第一个元素(这是第一个mp3文件),0是随机范围的一部分!

4)Start mp3文件与您的默认程序(VLC,WMPlayer等...),如果有必要,Windows将要求默认程序。

@echo off
Setlocal EnableDelayedExpansion

set "Music_PATH=C:\Users\ptldk\Documents\Batch\Batch Support\Random Happy Music Playlist"
set counter=0

for /f "tokens=*" %%a in ('forfiles /p "%Music_PATH%" /m *mp3') do (
    set Rand_PATH[!counter!]=%%~nxa
    set /a counter+=1
)

set /a Random_Music=%random% %% %counter%
set "Full_PATH=%Music_PATH%\!Rand_PATH[%Random_Music%]!"

echo Random Music & echo. & echo !Rand_PATH[%Random_Music%]!
start "" "%Full_PATH%"

pause >nul

答案 1 :(得分:1)

您可以尝试使用此vbscript

'***********************************Description*************************************
'This Vbscript scan into a folder and its subfolders for songs like .mp3 .mp4 .wav .....
'And create a playlist in a text file in order to play it in the background.
'© Hackoo © 2015
'***********************************************************************************
Option Explicit
If AppPrevInstance() Then 
    MsgBox "There is an existing proceeding !" & VbCrLF &_
    CommandLineLike(WScript.ScriptName),VbExclamation,"There is an existing proceeding !"    
    WScript.Quit   
Else 
    Dim Folder,File,fso,MyPlayList,Temp,oExec,ws,Title,WaitingMsg
    Set fso = CreateObject("Scripting.FileSystemObject")
    Set ws = CreateObject("WScript.Shell")
    Temp = ws.ExpandEnvironmentStrings("%Temp%")
    Folder = Browse4Folder()
    MyPlayList = Folder & "\MyPlayList.txt"
    If fso.FileExists(MyPlayList) Then
        fso.DeleteFile(MyPlayList)
    End If
    Title = "Looking for songs in "& DblQuote(Folder) & " using Vbscript © Hackoo 2015"
    WaitingMsg = "Please wait... Searching for songs into : <font color=Yellow>"& DblQuote(Folder) & "</font> is in progress..."
    Call CreateProgressBar(Title,WaitingMsg)'Creation of Waiting Bar
    Call LancerProgressBar() 'Launch of the Waiting Bar
    Call Pause(10)
    Call Scan4Songs(Folder)
    Call FermerProgressBar()
    Call Play(MyPlayList)
End If
'*********************************************************
Sub Play(File)
    On Error Resume Next
    Dim Sound,Xwmp
    Dim fso,F,ReadME,PlayList,i,Ws,Copyright,Name,Duration
    Copyright = " © Hackoo © 2015"
    Set Ws = CreateObject("wscript.Shell")
    Set fso = CreateObject("Scripting.FileSystemObject")
    Set F = fso.OpenTextFile(File,1)
    If Err <> 0 Then
        Ws.popup Err.Description & VbCrlF &_
        "No media file found !","3",Err.Description & Copyright,VbCritical
        wscript.quit()
    End If
    ReadMe = F.ReadAll
    PlayList = split(ReadMe,vbcrlf)
    Set Sound = CreateObject("WMPlayer.OCX")
    Sound.settings.volume = 100
    Sound.currentPlaylist.Clear
    For i = Lbound(PlayList) to Ubound(PlayList)
        Set Xwmp = Sound.newMedia(PlayList(i))
        Sound.currentPlaylist.insertItem(i),Xwmp
        Sound.Controls.Play()   
        Do while Sound.currentmedia.duration = 0
            wscript.sleep 100
        Loop
        wscript.sleep(int(Sound.currentmedia.duration)+1)*1000
    Next    
End Sub
'*********************************************************************************************
Function AppPrevInstance()   
    With GetObject("winmgmts:" & "{impersonationLevel=impersonate}!\\.\root\cimv2")   
        With .ExecQuery("SELECT * FROM Win32_Process WHERE CommandLine LIKE " & CommandLineLike(WScript.ScriptFullName) & _
            " AND CommandLine LIKE '%WScript%' OR CommandLine LIKE '%cscript%'")   
            AppPrevInstance = (.Count > 1)   
        End With   
    End With   
End Function    
'*********************************************************************************************
Function CommandLineLike(ProcessPath)   
    ProcessPath = Replace(ProcessPath, "\", "\\")   
    CommandLineLike = "'%" & ProcessPath & "%'"   
End Function
'*********************************************************************************************
Function Browse4Folder()
    Dim objShell,objFolder,Message
    Message = "Please select a folder in order to scan into it and its subfolders for songs"
    Set objShell = CreateObject("Shell.Application")
    Set objFolder = objShell.BrowseForFolder(0,Message,1,"c:\Programs")
    If objFolder Is Nothing Then
        Wscript.Quit
    End If
    Browse4Folder = objFolder.self.path
end Function
'*********************************************************************************************
Function Scan4Songs(Folder)
    Dim File,Ext,i,SubFolder
    Set Folder = fso.GetFolder(Folder)
    For each File in Folder.Files
        Ext = Array("mp4","mp3","wav","ogg","asf","aa3","m3v","midi")
        For i = LBound(Ext) To UBound(Ext)
            If LCase(fso.GetExtensionName(File.name)) = LCase(Ext(i)) Then 
                Call MakePlayListFile(MyPlayList,File.Path)
            end if
        Next
    Next
    For each SubFolder in Folder.SubFolders
        Call Scan4Songs(SubFolder.Path)
    Next
End Function
'*********************************************************************************************
Sub MakePlayListFile(MyPlayList,strContents)
    Dim fso,ts
    Const ForAppending= 8
    Set fso = CreateObject("Scripting.FileSystemObject")
    Set ts = fso.OpenTextFile(MyPlayList,ForAppending,True)
    ts.WriteLine strContents
    ts.Close
End Sub
'**********************************************************************************************
Sub CreateProgressBar(Title,WaitingMsg)
    Dim ws,fso,f,f2,ts,ts2,Ligne,i,fread,LireTout,NbLigneTotal,Temp,PathOutPutHTML,fhta,oExec
    Set ws = CreateObject("wscript.Shell")
    Set fso = CreateObject("Scripting.FileSystemObject")
    Temp = WS.ExpandEnvironmentStrings("%Temp%")
    PathOutPutHTML = Temp & "\Barre.hta"
    Set fhta = fso.OpenTextFile(PathOutPutHTML,2,True)
    fhta.WriteLine "<HTML>"
    fhta.WriteLine "<HEAD>"
    fhta.WriteLine "<Title>  " & Title & "</Title>"
    fhta.WriteLine "<HTA:APPLICATION"
    fhta.WriteLine "ICON = ""magnify.exe"" "
    fhta.WriteLine "BORDER=""THIN"" "
    fhta.WriteLine "INNERBORDER=""NO"" "
    fhta.WriteLine "MAXIMIZEBUTTON=""NO"" "
    fhta.WriteLine "MINIMIZEBUTTON=""NO"" "
    fhta.WriteLine "SCROLL=""NO"" "
    fhta.WriteLine "SYSMENU=""NO"" "
    fhta.WriteLine "SELECTION=""NO"" "
    fhta.WriteLine "SINGLEINSTANCE=""YES"">"
    fhta.WriteLine "</HEAD>"
    fhta.WriteLine "<BODY text=""white""><CENTER>"
    fhta.WriteLine "<marquee DIRECTION=""LEFT"" SCROLLAMOUNT=""3"" BEHAVIOR=ALTERNATE><font face=""Comic sans MS"">" & WaitingMsg &"</font></marquee>"
    fhta.WriteLine "<img src="""" />"
    fhta.WriteLine "</CENTER></BODY></HTML>"
    fhta.WriteLine "<SCRIPT LANGUAGE=""VBScript""> "
    fhta.WriteLine "Set ws = CreateObject(""wscript.Shell"")"
    fhta.WriteLine "Temp = WS.ExpandEnvironmentStrings(""%Temp%"")"
    fhta.WriteLine "Sub window_onload()"
    fhta.WriteLine "    CenterWindow 500,100"
    fhta.WriteLine "    Self.document.bgColor = ""DarkOrange"" "
    fhta.WriteLine " End Sub"
    fhta.WriteLine " Sub CenterWindow(x,y)"
    fhta.WriteLine "    Dim iLeft,itop"
    fhta.WriteLine "    window.resizeTo x,y"
    fhta.WriteLine "    iLeft = window.screen.availWidth/2 - x/2"
    fhta.WriteLine "    itop = window.screen.availHeight/2 - y/2"
    fhta.WriteLine "    window.moveTo ileft,itop"
    fhta.WriteLine "End Sub"
    fhta.WriteLine "</script>"
    fhta.close
End Sub
'**********************************************************************************************
Sub LancerProgressBar()
    Set oExec = Ws.Exec("mshta.exe " & Temp & "\Barre.hta")
End Sub
'**********************************************************************************************
Sub FermerProgressBar()
    oExec.Terminate
End Sub
'**********************************************************************************************
Function DblQuote(Str)
    DblQuote = Chr(34) & Str & Chr(34)
End Function
'**********************************************************************************************
Sub Pause(Secs)    
    Wscript.Sleep(Secs * 1000)    
End Sub   
'**********************************************************************************************

答案 2 :(得分:-1)

我在Hackoo的优秀代码中添加了一个Randomize函数。

'***********************************Description*************************************
'This Vbscript scan into a folder and its subfolders for songs like .mp3 .mp4 .wav .....
'And create a playlist in a text file in order to play it in the background.
'© Hackoo © 2015
' updated fx 2016
'***********************************************************************************
Option Explicit
If AppPrevInstance() Then 
    MsgBox "There is an existing proceeding !" & VbCrLF &_
    CommandLineLike(WScript.ScriptName),VbExclamation,"There is an existing proceeding !"    
    WScript.Quit   
Else 
Dim Folder,File,fso,MyPlayList,Temp,oExec,ws,Title,WaitingMsg
Set fso = CreateObject("Scripting.FileSystemObject")
Set ws = CreateObject("WScript.Shell")
Temp = ws.ExpandEnvironmentStrings("%Temp%")
Folder = Browse4Folder()
MyPlayList = Folder & "\_MyPlayList.txt"
If fso.FileExists(MyPlayList) Then
    fso.DeleteFile(MyPlayList)
End If
Title = "Looking for songs in "& DblQuote(Folder) & " using Vbscript © Hackoo 2015"
WaitingMsg = "Please wait... Searching for songs into : <font color=Yellow>"& DblQuote(Folder) & "</font> is in progress..."
Call CreateProgressBar(Title,WaitingMsg)'Creation of Waiting Bar
Call LancerProgressBar() 'Launch of the Waiting Bar
Call Pause(10)
Call Scan4Songs(Folder)
Call FermerProgressBar()
Call Play(MyPlayList)
End If
'*********************************************************
Sub Play(File)
On Error Resume Next
Dim Sound,Xwmp
Dim fso,F,ReadME,PlayList,i,Ws,Copyright,Name,Duration
Copyright = " © Hackoo © 2015"
Set Ws = CreateObject("wscript.Shell")
Set fso = CreateObject("Scripting.FileSystemObject")
Set F = fso.OpenTextFile(File,1)
If Err <> 0 Then
    Ws.popup Err.Description & VbCrlF &_
    "No media file found !","3",Err.Description & Copyright,VbCritical
    wscript.quit()
End If
ReadMe = F.ReadAll
PlayList = split(ReadMe,vbcrlf)
Set Sound = CreateObject("WMPlayer.OCX")
Sound.settings.volume = 100
Sound.currentPlaylist.Clear
For i = Lbound(PlayList) to Ubound(PlayList)
    Set Xwmp = Sound.newMedia(PlayList(i))
    Sound.currentPlaylist.insertItem(i),Xwmp
    Sound.Controls.Play()   
    Do while Sound.currentmedia.duration = 0
        wscript.sleep 100
    Loop
    wscript.sleep(int(Sound.currentmedia.duration)+1)*1000
Next    
End Sub
'*********************************************************************************************
Function AppPrevInstance()   
With GetObject("winmgmts:" & "{impersonationLevel=impersonate}!\\.\root\cimv2")   
    With .ExecQuery("SELECT * FROM Win32_Process WHERE CommandLine LIKE " & CommandLineLike(WScript.ScriptFullName) & _
        " AND CommandLine LIKE '%WScript%' OR CommandLine LIKE '%cscript%'")   
        AppPrevInstance = (.Count > 1)   
    End With   
End With   
End Function    
'*********************************************************************************************
Function CommandLineLike(ProcessPath)   
ProcessPath = Replace(ProcessPath, "\", "\\")   
CommandLineLike = "'%" & ProcessPath & "%'"   
End Function
'*********************************************************************************************
Function Browse4Folder()
Dim objShell,objFolder,Message
Message = "Please select a folder in order to scan into it and its subfolders for songs"
Set objShell = CreateObject("Shell.Application")
Set objFolder = objShell.BrowseForFolder(0,Message,1,"c:\Programs")
If objFolder Is Nothing Then
    Wscript.Quit
End If
Browse4Folder = objFolder.self.path
end Function
'*********************************************************************************************
Function Scan4Songs(Folder)
Dim File,Ext,i,SubFolder
Dim listArr(),RandArr()
Dim j,n,boo

j=0
Set Folder = fso.GetFolder(Folder)
For each File in Folder.Files
    Ext = Array("mp4","mp3","wav","ogg","asf","aa3","m3v","midi")
    For i = LBound(Ext) To UBound(Ext)
        If LCase(fso.GetExtensionName(File.name)) = LCase(Ext(i)) Then 
            ''Call MakePlayListFile(MyPlayList,File.Path)
            ''Call MakePlayListFile(MyPlayList,File.Name) 
            if j=0 then 
               redim listArr(1)
            else
               redim PRESERVE listArr(j+1)
            end if  
            ListArr(j)=File.Path
            j=j+1 
        end if
    Next
Next
if j > 0 then 
   Redim RandArr(ubound(listArr)) 
   for i=lbound(listArr) to ubound(listArr)
       Randomize
       n = int(Rnd * ubound(listArr))
       boo =false
       while not boo
          if IsEmpty(RandArr(n)) then 
             RandArr(n)=ListArr(i)
             boo=true  
          else
             n=n+1
             if n=ubound(listArr)+1 then 
                n=0
             end if 
          end if
       wend
   next
   for i=lbound(RandArr) to ubound(RandArr)
       if not IsEmpty(RandArr(i)) then 
          Call MakePlayListFile(MyPlayList,RandArr(i)) 
       end if
   next
end if 

For each SubFolder in Folder.SubFolders
    Call Scan4Songs(SubFolder.Path)
Next
End Function
    '*********************************************************************************************
Sub MakePlayListFile(MyPlayList,strContents)
Dim fso,ts
Const ForAppending= 8
Set fso = CreateObject("Scripting.FileSystemObject")
Set ts = fso.OpenTextFile(MyPlayList,ForAppending,True)
ts.WriteLine strContents
ts.Close
End Sub
'**********************************************************************************************
Sub CreateProgressBar(Title,WaitingMsg)
Dim ws,fso,f,f2,ts,ts2,Ligne,i,fread,LireTout,NbLigneTotal,Temp,PathOutPutHTML,fhta,oExec
Set ws = CreateObject("wscript.Shell")
Set fso = CreateObject("Scripting.FileSystemObject")
Temp = WS.ExpandEnvironmentStrings("%Temp%")
PathOutPutHTML = Temp & "\Barre.hta"
Set fhta = fso.OpenTextFile(PathOutPutHTML,2,True)
fhta.WriteLine "<HTML>"
fhta.WriteLine "<HEAD>"
fhta.WriteLine "<Title>  " & Title & "</Title>"
fhta.WriteLine "<HTA:APPLICATION"
fhta.WriteLine "ICON = ""magnify.exe"" "
fhta.WriteLine "BORDER=""THIN"" "
fhta.WriteLine "INNERBORDER=""NO"" "
fhta.WriteLine "MAXIMIZEBUTTON=""NO"" "
fhta.WriteLine "MINIMIZEBUTTON=""NO"" "
fhta.WriteLine "SCROLL=""NO"" "
fhta.WriteLine "SYSMENU=""NO"" "
fhta.WriteLine "SELECTION=""NO"" "
fhta.WriteLine "SINGLEINSTANCE=""YES"">"
fhta.WriteLine "</HEAD>"
fhta.WriteLine "<BODY text=""white""><CENTER>"
fhta.WriteLine "<marquee DIRECTION=""LEFT"" SCROLLAMOUNT=""3"" BEHAVIOR=ALTERNATE><font face=""Comic sans MS"">" & WaitingMsg &"</font></marquee>"
fhta.WriteLine "<img src="""" />"
fhta.WriteLine "</CENTER></BODY></HTML>"
fhta.WriteLine "<SCRIPT LANGUAGE=""VBScript""> "
fhta.WriteLine "Set ws = CreateObject(""wscript.Shell"")"
fhta.WriteLine "Temp = WS.ExpandEnvironmentStrings(""%Temp%"")"
fhta.WriteLine "Sub window_onload()"
fhta.WriteLine "    CenterWindow 500,100"
fhta.WriteLine "    Self.document.bgColor = ""DarkOrange"" "
fhta.WriteLine " End Sub"
fhta.WriteLine " Sub CenterWindow(x,y)"
fhta.WriteLine "    Dim iLeft,itop"
fhta.WriteLine "    window.resizeTo x,y"
fhta.WriteLine "    iLeft = window.screen.availWidth/2 - x/2"
fhta.WriteLine "    itop = window.screen.availHeight/2 - y/2"
fhta.WriteLine "    window.moveTo ileft,itop"
fhta.WriteLine "End Sub"
fhta.WriteLine "</script>"
fhta.close
End Sub
'**********************************************************************************************
Sub LancerProgressBar()
Set oExec = Ws.Exec("mshta.exe " & Temp & "\Barre.hta")
End Sub
'**********************************************************************************************
Sub FermerProgressBar()
oExec.Terminate
End Sub
'**********************************************************************************************
Function DblQuote(Str)
DblQuote = Chr(34) & Str & Chr(34)
End Function
'**********************************************************************************************
Sub Pause(Secs)    
Wscript.Sleep(Secs * 1000)    
End Sub   
'******************************************************************************************