Компьютерный форум OSzone.net  

Компьютерный форум OSzone.net (http://forum.oszone.net/index.php)
-   Скриптовые языки администрирования Windows (http://forum.oszone.net/forumdisplay.php?f=102)
-   -   [решено] Чтение и запись в файл (http://forum.oszone.net/showthread.php?t=211624)

Dt83 21-07-2011 14:51 1717173

Чтение и запись в файл
 
Добрый день!


Не могу понять как реализовать порядковую нумерацию создаваемых архивов. Например существует 2 папки 1 и 2. При запуске скрипта, проверяется наличие файлов сначала в папке 1 (если есть, то закручивается архив с именем опр. маски), затем наличие файлов в папке 2 (если есть закручивается архив с именем опр. маски). Нужно чтобы в имени создаваемых архивов помимо маски добавлялась порядковая нумерация начиная с 01 (маска имени архива берется по маске имени закручиваемого файла). Т.е. если при первом запуске при наличии файлов в обеих папках закрутилось два архива (например: *01.arj, *02.arj), то при повторном запуске скрипта при наличии файлов хотя бы в одной папке образовался архив с именем *03.arj (порядковая нумерация идет в течении дня, на след. день архивы снова должны нумероваться с 01). Пока есть идея создать какой нибудь текстовичок, в кот. бы велась запись порядковых номеров, но не совсем понятно как прочитать последнюю строку этого текстовичка. Может быть есть еще какие то способы?
Спасибо!

Вот что пока написала:


iDir1 = "D:\test\1"
iDir2 = "D:\test\2"

Maska = "SBC........._............_................_...\.txt$"

ForReading = 1
rem---------------------------------------------------------------
rem Проверяем сущестование директорий

rem ---Проверяем сущестование D:\test\1---
Set objFSO = CreateObject("Scripting.FileSystemObject")
If objFSO.FolderExists(iDir1) Then
Set objFolder = objFSO.GetFolder(iDir1)

Set FSO = WScript.CreateObject("Scripting.FileSystemObject")
set Files = FSO.GetFolder(iDir1).Files

Set Re = New RegExp
Re.Pattern = Maska
Re.IgnoreCase = True
Set WshShell = CreateObject("WScript.Shell")

For Each File In Files

If Re.Test(File.Name) Then
str1="A"&Mid(File.Name,8,5)&Mid(File.Name,20,6)
WshShell.Run ("""C:\Program Files\7-Zip\7z""a -tzip """+iDir1+"\"+str1+".arj"" -r """+iDir1+"\*.txt""")


end if
next
Else
Wscript.Echo "Не найдена директория D:\test\1"
End If



rem ---Проверяем сущестование D:\test\2---
Set objFSO1 = CreateObject("Scripting.FileSystemObject")
If objFSO1.FolderExists(iDir2) Then
Set objFolder1 = objFSO1.GetFolder(iDir2)
Set FSO1 = WScript.CreateObject("Scripting.FileSystemObject")
set Files1 = FSO1.GetFolder(iDir2).Files

Set Re = New RegExp
Re.Pattern = Maska
Re.IgnoreCase = True
Set WshShell = CreateObject("WScript.Shell")

For Each File1 In Files1
If Re.Test(File1.Name) Then
str2="C"&Mid(File1.Name,8,5)&Mid(File1.Name,20,6)
WshShell.Run ("""C:\Program Files\7-Zip\7z""a -tzip """+iDir2+"\"+str2+".arj"" -r """+iDir2+"\*.txt""")

end if
next
Else
Wscript.Echo "Не найдена директория D:\test\2"
End If

SendMessage 23-07-2011 11:56 1718295

Можно и с текстовичком. :)
Концепция такая - в том месте, где при создании архива должен выставляться его порядковый номер, вписать предлагаемую функцию.
Код:

CheckFile = "z:\check.txt"

'пример
archfile = "qwerty_" & SetNumberArchive(CheckFile) & ".arj"

Function SetNumberArchive(f)
  Dim arrCheck
  Dim CountArch
  Dim DateCheck
  Dim objFSO
    Set objFSO = CreateObject("Scripting.FileSystemObject")
    If objFSO.FileExists(f) Then
      arrCheck = Split(objFSO.OpenTextFile(f).ReadLine, "#", 2)
      DateCheck = arrCheck(0)
      CountArch = arrCheck(1) + 1
    End If
    If Not CDate(DateCheck) = Date Then CountArch = 1
    objFSO.OpenTextFile(f, 2, True).Write Date & "#" & CountArch
    SetNumberArchive = CountArch
End Function

Думаю, разобраться несложно. Функция регистрирует свои запуски в определенную дату.

Dt83 25-07-2011 11:48 1719350

правильно я понимаю функция регистрирует запуски начиная нумерацию с 1?

SendMessage 25-07-2011 13:10 1719415

Цитата:

Цитата Dt83
правильно я понимаю функция регистрирует запуски начиная нумерацию с 1? »

Да.

Dt83 25-07-2011 13:23 1719423

не могу разобраться чтобы нумерация шла с 01...спасибо!

SendMessage 25-07-2011 14:14 1719471

Цитата:

Цитата Dt83
чтобы нумерация шла с 01 »

Right("0" & SetNumberArchive(CheckFile), 2) - нумерация от 01 до 99
Right("00" & SetNumberArchive(CheckFile), 3) - нумерация от 001 до 999
Ну и т. д.

Dt83 25-07-2011 14:29 1719479

Спасибо большое!


Время: 07:08.

Время: 07:08.
© OSzone.net 2001-