6 / 6 / 6
Регистрация: 10.03.2011
Сообщений: 88
VBS

Печать PDF-файлов из разных папок одной кнопкой

26.10.2014, 18:08. Показов 4341. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Доброго времени суток, уважаемые форумчане!
хочется научиться писать скрипты на vbs, используя реальные задачи.
пожалуйста, помогите разобраться, есть задача:
в каждой папке на сервере '\\server1\share1', '\\server1\share2', '\\server1\share3', '\\server1\share4' находится любое количество файлов *.pdf с любым именем.
используя HTA+VBScript создать глюкалу, которая будет формировать список из выбранных пользователем папок, что указаны выше (может быть, использовать чекбоксы? или два листбокса друг напротив друга, из одного в другой добавлять папки?).
Далее, должна быть суперкнопка, которая заставит напечататься все файлы *.pdf из этих (выбранных) папок на принтер "по умолчанию".
по поводу печати, нашел скрипт - AutoIT. Он висит в системе и ждет, пока в заданной папке не появиться файлик ПДФ, тут же хватает его, печатает и удаляет.
Исходя из вышеизложенного, натолкнулся на мысль, что HTA+VBScript остается заставить создавать массив из списка папок-исходников и циклом, пробегаясь по этим папкам, копировать из них файлики в заветную папку 'X:\print', в которой их будет поджидать наш скриптик AutoIT. Осмелюсь предположить, что на каждой итерации цикла необходимо делать паузу около 3 секунд (+/- ?). Напомню, что делается все для обычных пользователей (которые паникуют, что у них "интернет с компьютера удалили", когда не могут обнаружить ярлык браузера на привычном месте рабочего стола).

Спасибо за понимание.
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
26.10.2014, 18:08
Ответы с готовыми решениями:

Автоматическая печать документов из разных папок в одной директории
Друзья, нужна ваша помощь! Возможно ли создать макрос, который в выбранной директории поочередно будет открывать документы с определенным...

Копирование файлов из папок в разных пользовательских профилях в папки на разных дисках
Здравствуйте, нужна очень ваша помощь. У меня есть BAT файлик вот с такой командой пример. xcopy...

Как добавить несколько файлов одной кнопкой и в одной форме php
Здравствуйте! Как добавить несколько файлов одной кнопкой и в одной форме php Например есть такая форма: <form method='POST'...

4
2619 / 549 / 109
Регистрация: 21.03.2012
Сообщений: 1,051
27.10.2014, 00:41
Цитата Сообщение от Symba Посмотреть сообщение
... копировать из них файлики в заветную папку 'X:\print', в которой их будет поджидать наш скриптик AutoIT...
Вполне можно обойтись без дополнительного сценария на AutoIT. Пример сценария отправки на печать одного файла на "умолчальный" принтер:
Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
Dim objFS, objShell, strFile, strPath, strArguments, strVerb, intShowMode
strFile = "1.pdf": strArguments = "": strPath = "D:\Temp": strVerb = "print": intShowMode = 0
Set objFS = CreateObject("Scripting.FileSystemObject")
If objFS.FileExists(objFS.BuildPath(strPath, strFile)) Then
    Set objShell = CreateObject("Shell.Application")
    Set objFolder = objShell.NameSpace(&h4)
    If objShell.NameSpace(&h4).Items.Count > 1 Then
        On Error Resume Next
        objShell.ShellExecute strFile, strArguments, strPath, strVerb, intShowMode
        If Err.Number = 0 Then
            WScript.Echo "Задание печати обработано успешно."
        Else
            WScript.Echo "Ошибка " & Err.Number & " при обработке задания печати." & vbNewLine & Err.Description
            Err.Clear
        End If
    Else
        WScript.Echo "Не найдено ни одного подключения к принтеру."
    End If
    Set objShell = Nothing
Else
    WScript.Echo "Не найден путь " & objFS.BuildPath(strPath, strFile)
End If
Set objFS = Nothing
WScript.Quit 0
P.S.
Тема размещена не по адресу. Вам нужна ветка форума VBScript/JScript/WSH/WMI/HTA.
2
6 / 6 / 6
Регистрация: 10.03.2011
Сообщений: 88
27.10.2014, 07:11  [ТС]
Цитата Сообщение от Dmitrii Посмотреть сообщение
Пример сценария отправки на печать одного файла на "умолчальный" принтер:
Благодарю, а как несколько файликов из разных папок с разными (не статичными) именами печатать?

Цитата Сообщение от Dmitrii Посмотреть сообщение
Тема размещена не по адресу. Вам нужна ветка форума VBScript/JScript/WSH/WMI/HTA.
просьба к администрации: перенесите тему в соответствующй раздел, пожалуйста. Видимо, плохо искал, раз не нашел. Спасибо!
0
2619 / 549 / 109
Регистрация: 21.03.2012
Сообщений: 1,051
27.10.2014, 20:12
Лучший ответ Сообщение было отмечено ComSpec как решение

Решение

Цитата Сообщение от Symba Посмотреть сообщение
... как несколько файликов из разных папок с разными (не статичными) именами печатать?
Пример отправки на печать всех файлов, соответствующих заданной маске, из заданного набора папок - ниже.
Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
Dim objFS, objShell, objFolderItems
Dim strMask, arrFolders, strArguments, strVerb, intShowMode, strTemp, i, j
 
strMask = "*.pdf": strArguments = "": strVerb = "print": intShowMode = 0
arrFolders = Array("D:\Temp", "E:\Temp")
Set objShell = CreateObject("Shell.Application")
If objShell.NameSpace(&h4).Items.Count > 1 Then
    Set objFS = CreateObject("Scripting.FileSystemObject")
    For i = 0 To UBound(arrFolders)
        If objFS.FolderExists(arrFolders(i)) Then
            Set objFolderItems = objShell.NameSpace(arrFolders(i)).Items
            objFolderItems.Filter 64 + 128, strMask
            On Error Resume Next
            For j = 0 To objFolderItems.Count - 1
                strTemp = objFolderItems.Item(j).Name
                objShell.ShellExecute strTemp, strArguments, arrFolders(i), strVerb, intShowMode
                If Err.Number = 0 Then
                    WScript.Echo "Задание печати файла " & strTemp & " обработано успешно."
                Else
                    WScript.Echo "Ошибка " & Err.Number & " при печати файла " & strTemp & vbNewLine & Err.Description
                    Err.Clear
                End If
            Next
            On Error GoTo 0
        Else
            WScript.Echo "Не найден путь " & arrFolders(i)
        End If
    Next
    Set objFolderItems = Nothing: Set objFS = Nothing
Else
    WScript.Echo "Не найдено ни одного подключения к принтеру."
End If
Set objShell = Nothing
WScript.Quit 0
2
6 / 6 / 6
Регистрация: 10.03.2011
Сообщений: 88
28.10.2014, 19:21  [ТС]
Цитата Сообщение от Dmitrii Посмотреть сообщение
Пример отправки на печать всех файлов
Благодарю! то, что нужно! буду дорабатывать, итоговый вариант запостю сюда!
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
28.10.2014, 19:21
Помогаю со студенческими работами здесь

Печать документа word одной кнопкой
Есть кнопка на форме. Необходимо что бы она выполняла операцию печати документа хранящиеся на диске C:\БД\Document.doc

Открытие разных отчетов одной кнопкой
Здравствуйте! В форме "Выбор анализа" у меня есть поле "Год и месяц" (заполняется по принципу, если 1211 это означает 2012 год 11 месяц,...

Выполнение разных процедур одной и той же кнопкой
Option Explicit On Imports System Imports Microsoft.Win32 Imports System.IO Imports System.Text Imports System.ServiceProcess ...

Печать pdf файлов
Доброго времени суток! Есть папка, в папке много pdf файлов, которые надо распечатать в определенном порядке (печатать в алфавитном...

Печать pdf файлов
Добрый день! Необходимо, чтобы программа печатала все pdf файлы из определенной папки. Как это можно реализовать? Спасибо!


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Опции темы

Новые блоги и статьи
Валидация и контроль данных табличной части документа перед записью
Maks 22.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в КА2. Задача: контроль и валидация данных табличной части документа перед записью с учетом регламента компании. . .
Отчёт о затраченных материалах за определенный период с макетом печатной формы
Maks 21.04.2026
Отчёт из решения ниже размещён в конфигурации КА2. Задача: разработка отчёта по затраченным материалам за определённый период, с возможностью вывода печатной формы отчёта с шапкой и подвалом. В. . .
Отчёт о спецтехнике находящейся в ремонте
Maks 20.04.2026
Отчёт из решения ниже размещен в конфигурации КА2. Задача: отобразить спецтехнику, которая на данный момент находится в ремонте. Есть нетиповой документ "Заявка на ремонт спецтехники" который. . .
Памятка для бота и "визитка" для читателей "Semantic Universe Layer (Слой семантической вселенной)"
Hrethgir 19.04.2026
Сгенерировано для краткого описания по случаю сборки и компиляции скелета серверного приложения. И пусть после этого скажут, что статьи сгенерированные AI - туфта и не интересно. И это не реклама -. . .
Запрет удаления строк ТЧ документа при определённом условии
Maks 19.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "Аккумуляторы", разработанного в конфигурации КА2. У данного документа есть ТЧ, в которой в зависимости от прав доступа. . .
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут Суть: - Группа наркоманов из 10 человек. - Только один инфицирован ВИЧ. - Колются одной иглой. - Колются раз в день. - Колются последовательно через. . .
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru