どうぞ:
Option Explicit             
Const ForReading = 1                
Const ForWriting = 2                
Const ForAppending = 8              
Sub collectData()               
    Dim WshShell, sPath, sMain, sName, sDesc, sPrice, sContact          
    ' Save it to a folder on the Desktop            
    set WshShell = WScript.CreateObject("WScript.Shell")            
    sPath = WshShell.SpecialFolders("Desktop")          
    sPath = sPath & "\Scratch Files\"           
    sMain = "Bulletin.html"         
    ' Prompt for title, description, price, and contact         
    sName = getInput("Item Name")           
    sDesc = getInput("Item Description")            
    sPrice = getInput("Item Price")         
    sContact = getInput("Contact Information")          
    Call createFile(sPath, sName, sDesc, sPrice, sContact)          
    ' Add new .html file to index file in the format: date, <a href=html location>title for link</a>            
    Call appendFile(sPath, sMain, sName)            
    set WshShell = Nothing  
    Call Msgbox("Your item (" & sName & ") was added")
End Sub             
Function getInput(prompt)               
    getInput = inputbox(prompt,"Add New Item for Sale")         
End Function                
sub createFile(sPath, sName, sDesc, sPrice, sContact)               
    'Creates a new file, or appends to an existing file         
    Dim objFSO, objArgs(19), sTextFile, objFile, i          
    ' Create the File System Object         
    Set objFSO = CreateObject("Scripting.FileSystemObject")         
    ' Check if folder path exists; if not, create folder            
    If objFSO.FolderExists(sPath) then          
    Else            
        Call objFSO.CreateFolder(sPath)     
    End If          
    ' Save file as <title of item>.html         
    sTextFile = sPath & sName & ".html"             
    ' If file exists, open; else, create it         
    If objFSO.FileExists(sTextFile) Then            
        Set objFile = objFSO.OpenTextFile(sTextFile, ForAppending)      
    Else            
        Set objFile = objFSO.CreateTextFile(sTextFile)      
    End If          
    objArgs(1) = "<HTML>"           
    objArgs(2) = "    <HEAD>"           
    objArgs(3) = "        <TITLE>Bulletin</TITLE>"          
    objArgs(4) = "    </HEAD>"          
    objArgs(5) = ""         
    objArgs(6) = "<BODY>"           
    objArgs(7) = "    <CENTER><H1>Bulletin</H1></CENTER>"           
    objArgs(8) = "<!-Item Name-!>"          
    objArgs(9) = "    <H1>" & sName & "</H1> "          
    objArgs(10) = "<!-Item Price-!>"            
    objArgs(11) = "    <H2><U>" & sPrice & "</U></H2>"          
    objArgs(12) = "<!-Contact Info-!>"          
    objArgs(13) = "    <b><Font Color='Blue'>" & sContact & "</b></font>"           
    objArgs(14) = "        <BR /><BR /><BR />"          
    objArgs(15) = "<!-Item Description-!>"          
    objArgs(16) = "    " & sDesc            
    objArgs(17) = "</BODY>"         
    objArgs(18) = "</HTML>"         
    ' Write the details to the file         
    For i = 1 To UBound(objArgs)            
        objFile.WriteLine objArgs(i) & " "      
    Next            
    ' Append a newline character            
    objFile.WriteLine           
    ' Close the file            
    objFile.Close           
    set objFile = Nothing           
    set objFSO = Nothing            
End Sub             
Sub appendFile(sPath, sMain, sName)             
    Dim objFSO, objArgs(3), sTextFile, objFile, file, i, lBody          
    ' Create the File System Object         
    Set objFSO = CreateObject("Scripting.FileSystemObject")         
    ' Check if folder path exists; if not, create folder            
    If objFSO.FolderExists(sPath) then          
    Else            
        Call objFSO.CreateFolder(sPath)     
    End If          
    'Create filename            
    sTextFile = sPath & sMain           
    ' If file exists, open; else, create it         
    If objFSO.FileExists(sTextFile) Then            
        Set objFile = objFSO.OpenTextFile(sTextFile, ForReading)        
        file = Split(objFile.ReadAll(), vbCrLf)     
        objFile.Close()     
        Set objFile = objFSO.OpenTextFile(sTextFile, ForWriting)        
        For i = Lbound(file) to Ubound(file)        
            If inStr(file(i), "</BODY>") then   
                lBody = i
                Exit For
            Else    
                objFile.WriteLine(file(i))
            End If  
        Next        
    Else            
        Set objFile = objFSO.CreateTextFile(sTextFile)      
        file(1)=""      
    End If          
    objArgs(1) = Date() & " - <A HREF=""" & sName & ".html"">" & sName & " For Sale</A>"            
    objArgs(2) = "<BR /><BR />"         
    ' Write the details to the file         
    For i = 1 To UBound(objArgs)            
        objFile.WriteLine objArgs(i) & " "      
    Next            
    For i = lBody to Ubound(file)           
        objFile.WriteLine(file(i))      
    Next            
    ' Append a newline character            
    objFile.WriteLine           
    ' Close the file            
    objFile.Close           
    set objFile = Nothing           
    set objFSO = Nothing            
End Sub             
collectData()
ノート:
- collectData サブでは、ファイルを保存するパスを定義できます (現在、デスクトップの Scratch Files フォルダーにあります)。メインの Web ページ (現在は Bulletin.html) の名前を定義することもできます。
- どのプロンプトにもユーザー検証はありません (InputBox は関数 getInput にあります) が、自由に追加してください。getInput 関数のパラメーターの再調整が必要になる "$" のデフォルト値を含めたい場合があります (デフォルト値に別のパラメーターを追加し、inputbox(..) 呼び出しに 3 番目のパラメーターを含めます。詳細については、このページに従ってください。http://msdn.microsoft.com/en-us/library/3yfdhzk5%28v=vs.84%29.aspx )
- createFile() サブでテンプレートとして提供された HTML コードをモックアップしました。それを変更したい場合 (つまり、行を追加したい場合)、サブルーチンの上部近くにある objArgs 変数宣言も更新する必要があります。
- メイン Web ページの追加テンプレートについても同じことが言えますが (#3 を参照)、それは appendFile() サブにあります。
使用法:
- 新しいコンテンツを追加するには、ユーザーはコンピューター上の *.vbs ファイルをダブルクリックする必要があります。
- プロンプトは、アイテムを追加するための詳細を案内します。
- スクリプトが完了すると、自動的に *.html が作成され、メイン ページが更新され、素敵な MsgBox で通知されます (アイテムのアイテム名が追加されました)。
お役に立てれば。