Макрос в word открываем файл

0 / 0 / 0

Регистрация: 11.08.2016

Сообщений: 55

1

11.08.2016, 22:07. Показов 14841. Ответов 16


Студворк — интернет-сервис помощи студентам

Всем привет!Окажите содействие плиз: имеется папка с файлами .тхт необходим макрос который открывает все файлы из этой папки в Ворде(если возможно была признательна если можно было реализовать вывод диалогового окна выбора папки в котором сразу открывалась папка из которой нужно открыть файлы), затем нужно изменить на альбомную ориентацию , сделать 8 шрифт распечатать файл и сохранить в формате .doc .docx или .RTF тут не важно главное чтоб читался вордом и форматирование не слетало.Пробовала рекордером но получилось только изменение форматирования записать и печать. При сохранении он сохраняет одним и тем же именем т.е. в макрос записывается имя первого сохраняемого файла и все последующие пытается сохранить под тем же именем.такое реально реализовать ? Хелп ми))), около ста отчетов приходится лопатить вручную((((
З.Ы, если это упростит задачу все файлы имеют идентичные названия , например, report1, report2,report3 и т.д.



0



pashulka

4131 / 2235 / 940

Регистрация: 01.12.2010

Сообщений: 4,624

12.08.2016, 10:18

2

Попробуйте так (только тестировать, разумеется, нужно на нескольких файлах)

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
Private Sub Test()
    Dim iPath$, iFileName$
    iPath = "C:Мои отчёты"
    
    With Application.FileDialog(msoFileDialogFolderPicker)
         .Title = "Выберите папку с .txt файлами"
         .InitialFileName = iPath
         If .Show = -1 Then
            iPath = .SelectedItems(1) & ""
         Else
            MsgBox "Отказ от выбора папки", vbCritical: Exit Sub
         End If
    End With
    
    iFileName = Dir(iPath & "Report*.txt")
    If Len(iFileName) > 0 Then
       Application.ScreenUpdating = False
       Do
            With Documents.Open(iPath & iFileName, Encoding:=1251)
                 .Content.Font.Size = 8
                 .PrintOut
                 .SaveAs iPath & Replace(iFileName, _
                 ".txt", ".doc", , , vbTextCompare), wdFormatDocument
                 .Close
            End With
            'Kill iPath & iFileName
            iFileName = Dir
       Loop Until Len(iFileName) = 0
       Application.ScreenUpdating = True
    Else
       MsgBox "В выбранной папке нет наших файлов", vbCritical
    End If
End Sub

~ Тоже самое, но без сообщений

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
Private Sub Test2()
    Dim iPath$, iFileName$
    iPath = "C:Мои отчёты"
    
    With Application.FileDialog(msoFileDialogFolderPicker)
         .Title = "Выберите папку с .txt файлами"
         .InitialFileName = iPath
         If .Show = 0 Then Exit Sub
         iPath = .SelectedItems(1) & ""
    End With
    
    iFileName = Dir(iPath & "Report*.txt")
    Do Until Len(iFileName) = 0
       With Documents.Open(iPath & iFileName, , , , , , , , , wdOpenFormatText, 1251, False)
            .Content.Font.Size = 8
            .PrintOut
            .SaveAs iPath & Replace(iFileName, ".txt", ".doc", , , vbTextCompare), wdFormatDocument
            .Close
       End With
       'Kill iPath & iFileName
       iFileName = Dir
    Loop
End Sub



0



roneta90

0 / 0 / 0

Регистрация: 11.08.2016

Сообщений: 55

14.08.2016, 16:44

 [ТС]

3

Добавлено через 31 минуту
не получается! не находит файлы. пишет что в папке не найдены файлы.прилагаю скрины. и почему то не появился сам макрос в списке макросов. Наткнулась на такой макрос(см. ниже) Он работает но открывает Вордовские документы и меняет их(в данном случает стирается все содержимое) может его как то адаптировать под мою задачу:

Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
Option Explicit
Dim WordObj As Object
Dim WordDoc As Object
Dim MyPath As String
Dim iFileName As String
Sub Макрос1 ()
Set WordObj = CreateObject("Word.Application")
MyPath = "C:Report" 'указать пут к папке'
iFileName = Dir(MyPath) 'имя первого файла в папке Не менять!'
Do While iFileName <> ""
Set WordDoc = WordObj.Documents.Open(MyPath + iFileName) 'открываем первый файл в папке'
WordObj.Visible = True 'можно отображать можно не отображать'
iFileName = Dir 'получение следующего имени в папке Не менять!!!'
Loop
MsgBox "файлы обработаны", vbOKOnly + vbInformation, "оработка файлов"
End Sub

Миниатюры

Открыть файлы в Word VBA с помощью макроса
 

Открыть файлы в Word VBA с помощью макроса
 

Открыть файлы в Word VBA с помощью макроса



0



pashulka

4131 / 2235 / 940

Регистрация: 01.12.2010

Сообщений: 4,624

14.08.2016, 16:55

4

и правильно пишет, что не находит

ибо должен быть слэш, но форум его автоматически убирает. приходится вводить два слэша, но стоит забыть об этом правиле и …

Visual Basic
1
2
3
iPath = "C:Мои отчёты"
 
iPath = .SelectedItems(1) & ""



0



0 / 0 / 0

Регистрация: 11.08.2016

Сообщений: 55

16.08.2016, 21:17

 [ТС]

5

Не получается(( . Тоже самое. Может тогда оставим только чтобы менялся шрифт ориентация страницы и сохранение с именем исходного файла

Миниатюры

Открыть файлы в Word VBA с помощью макроса
 

Открыть файлы в Word VBA с помощью макроса
 



0



4131 / 2235 / 940

Регистрация: 01.12.2010

Сообщений: 4,624

16.08.2016, 21:47

6

Смотрите пример, где для чистоты эксперимента, необходимо выбрать папку «Test_for_Roneta90»



0



0 / 0 / 0

Регистрация: 11.08.2016

Сообщений: 55

28.08.2016, 17:20

 [ТС]

7

тоже самое)))Ладно , впринципе открою файлы с помощью cntrl+0 . тогда макрос прописать чтобы менял ориентацию шрифт и сохранял с текущим именем файла и в формате док или докх или ртф вообщем чтоб форматиование сохранялось



0



1 / 1 / 0

Регистрация: 12.06.2015

Сообщений: 93

07.09.2016, 21:10

8

а этот код подойдет для екселя, а не для ворда?
чтобы именно через ексель отркывался пусть к тхт файлам?



0



4131 / 2235 / 940

Регистрация: 01.12.2010

Сообщений: 4,624

07.09.2016, 21:41

9

Выбор папки и перебор .txt файлов можно использовать и в Excel



0



1 / 1 / 0

Регистрация: 12.06.2015

Сообщений: 93

07.09.2016, 21:45

10

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



0



4131 / 2235 / 940

Регистрация: 01.12.2010

Сообщений: 4,624

07.09.2016, 21:50

11

Проблема в людях, которые пытаются использовать диалог выбора папки, для указания файла, хотя для последнего есть свои варианты.



0



1 / 1 / 0

Регистрация: 12.06.2015

Сообщений: 93

07.09.2016, 21:57

12

какие варианты есть?



0



pashulka

4131 / 2235 / 940

Регистрация: 01.12.2010

Сообщений: 4,624

07.09.2016, 22:07

13

Visual Basic
1
Application.GetOpenFileName

Причём в справке есть готовый пример — для выбора .txt файла

или

Visual Basic
1
Application.FileDialog(msoFileDialogFilePicker)



0



1 / 1 / 0

Регистрация: 12.06.2015

Сообщений: 93

07.09.2016, 22:13

14

спасибо, а можно чтобы автоматически при этом открывалась определенная папка?



0



pashulka

4131 / 2235 / 940

Регистрация: 01.12.2010

Сообщений: 4,624

07.09.2016, 22:30

15

Для первого варианта ChDrive + ChDir, но если не прокатит, то во втором варианте есть свойство InitialFileName

Visual Basic
1
2
3
4
5
6
7
8
9
10
11
With Application.FileDialog(msoFileDialogFilePicker)
     .AllowMultiSelect = False
     .Title = "Выберите .txt файл"
     .Filters.Add "Text Files", "*.txt", 1
     .InitialFileName = Application.Path 'Укажите свою папку
     If .Show = -1 Then
         MsgBox .SelectedItems(1)
     Else
         MsgBox "Отказ от выбора файла", vbCritical
     End If
End With



0



Heroes

1 / 1 / 0

Регистрация: 12.06.2015

Сообщений: 93

07.09.2016, 22:47

16

у меня получилось так:

PureBasic
1
2
3
4
5
6
7
8
9
Sub Test()
 
 ChDir "C:Documents and SettingsuserМои документыTest"  ' путь какой-нужно
   Dim iFileName As Variant
   iFileName = Application.GetOpenFilename(" (*.txt),*.txt")
   
Workbooks.OpenText Filename:=iFileName  
  
 End Sub



0



pashulka

4131 / 2235 / 940

Регистрация: 01.12.2010

Сообщений: 4,624

07.09.2016, 23:09

17

Это прокатит только если в момент выполнения макроса текущим будет диск «C» и Вы не откажетесь от выбора файла. Т.е. более универсальным является следующий вариант (хотя и здесь, не помешало бы, проверить указанную папку на наличие)

Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
Private Sub Test()
     Dim iPath$, iFileName As Variant
     iPath = "C:Documents and SettingsUserМои документыTest"
     ChDrive Left(iPath, 2): ChDir iPath 'Можно просто ChDrive iPath
     
     iFileName = Application.GetOpenFilename("Text Files (*.txt),*.txt")
     If iFileName <> False Then
        Workbooks.OpenText FileName:=iFileName
     Else
        MsgBox "Зачем всё это нужно было ...", vbCritical
     End If
 End Sub



0



Если есть необходимость обратиться к данным, хранящимся в текстовом файле приложения Word, или наоборот, передать данные из Excel в такой файл, то возникнет необходимость запуска приложения, в формате которого сохранен файл. Ниже приведен программный код макроса VBA для Microsoft Excel, запускающий приложение Word.

Если для передачи данных из Excel в Word необходим новый документ, можно воспользоваться примером кода, приведенного ниже. Макрос проверяет запущен ли Word и если он запущен, то добавляет новый документ, если же не запущен, то сначала запускает Word, а затем добавляет новый документ.

Sub Zapusk_Word_iz_Excel_01()
    Dim objWrdApp As Object
    Dim objWrdDoc As Object
    On Error Resume Next
    Set objWrdApp = GetObject(, "Word.Application")
        If objWrdApp Is Nothing Then
            Set objWrdApp = CreateObject("Word.Application")
            Set objWrdDoc = objWrdApp.Documents.Add
            objWrdApp.Visible = True
        End If
    Set objWrdDoc = objWrdApp.Documents.Add
    Set objWrdDoc = Nothing
    Set objWrdApp = Nothing
End Sub

Для того, чтобы перенести этот программный код на свой компьютер, наведите курсор мыши на поле с программным кодом, нажмите на одну из двух кнопкок knopka_view_source в правом верхнем углу этого поля, скопируйте программный код и вставьте его в модуль проекта на своем компьютере (подробнее о том, как сохранить программный код макроса).

Макрос, запускающий Word из Excel и открывающий существующий документ

Если для передачи данных из Word в Excel, необходимо открыть файл с заданным именем, то можно использовать аналогичный код, в котором вместо добавления нового документа открывается документ существующий: 

Sub Zapusk_Word_iz_Excel_02()
    Dim objWrdApp As Object
    Dim objWrdDoc As Object
    On Error Resume Next
    Set objWrdApp = GetObject(, "Word.Application")
        If objWrdApp Is Nothing Then
            Set objWrdApp = CreateObject("Word.Application")
            Set objWrdDoc = objWrdApp.Documents.Open("C:Doc1.doc")
            objWrdApp.Visible = True
        End If
    Set objWrdDoc = objWrdApp.Documents.Open("C:Doc1.doc")
    Set objWrdDoc = Nothing
    Set objWrdApp = Nothing
End Sub

При копировании этого кода на свой компьютер, не забудьте изменить путь к файлу и его имя. Запуск приложения можно сделать невидимым, если в коде изменить True на False.

Макрос для передачи данных из Excel в Word

Ниже приведен программный код макроса, копирующий в активной рабочей книге Excel диапазон с данными A1:E2 и вставляющий его в открытый документ Word. После передачи данных из Excel в Word производится закрытие документа с сохранением изменений и выход из приложения.

Sub Peredacha_Dannyh_iz_Excel_v_Word()
    Dim objWrdApp As Object
    Dim objWrdDoc As Object
    On Error Resume Next
    Set objWrdApp = GetObject(, "Word.Application")
        If objWrdApp Is Nothing Then
            Set objWrdApp = CreateObject("Word.Application")
            Set objWrdDoc = objWrdApp.Documents.Open("C:Doc1.doc")
            objWrdApp.Visible = False
        End If
    Set objWrdDoc = objWrdApp.Documents.Open("C:Doc1.doc")
    Range("A1:E2").Copy
    objWrdDoc.Range(0).Paste
    objWrdDoc.Close True
    'True - с сохранением, False - без сохранения
    objWrdApp.Quit
    Set objWrdDoc = Nothing
    Set objWrdApp = Nothing
End Sub

Другие материалы по теме:

Создание нового документа Word или открытие существующего из кода VBA Excel. Методы Documents.Add и Documents.Open. Сохранение и закрытие документа.

Работа с Word из кода VBA Excel
Часть 2. Создание и открытие документов Word
[Часть 1] [Часть 2] [Часть 3] [Часть 4] [Часть 5] [Часть 6]

Новый документ Word создается из кода VBA Excel с помощью метода Documents.Add:

Sub Test1()

Dim myWord As New Word.Application

Dim myDocument As Word.Document

Set myDocument = myWord.Documents.Add

myWord.Visible = True

End Sub

Переменную myDocument можно объявить с типом Object, но тогда не будет ранней привязки к типу Word.Document и подсказок при написании кода (Auto List Members).

Открытие существующего документа

Существующий документ Word открывается из кода VBA Excel с помощью метода Documents.Open:

Sub Test2()

Dim myWord As New Word.Application

Dim myDocument As Word.Document

Set myDocument = _

myWord.Documents.Open(«C:Документ1.docx»)

myWord.Visible = True

End Sub

Замените в этой процедуре строку «C:Документ1.docx» на адрес своего файла.

Подключение к открытому документу

Присвоение переменной ссылки на существующий экземпляр Word.Application осуществляется в VBA Excel с помощью функции GetObject:

Sub Test3()

Dim myWord As Object, myDoc As Word.Document

On Error GoTo Instr

    Set myWord = GetObject(, «Word.Application»)

    Set myDoc = myWord.Documents(«Документ1.docx»)

    myDoc.Range.InsertAfter «Добавляем новый текст, подтверждающий подключение к открытому документу.»

Exit Sub

Instr:

    MsgBox «Произошла ошибка: « & Err.Description

End Sub

Если открытого приложения Word нет, выполнение функции GetObject приведет к ошибке. Также произойдет ошибка, если не будет найден указанный документ (в примере — «Документ1.docx»).

Сохранение и закрытие документа

Сохранение нового документа

Чтобы сохранить из кода VBA Excel новый документ Word, используйте метод SaveAs2 объекта Document:

myDocument.SaveAs2 («C:Документ2.docx»)

Замените «C:Документ2.docx» на путь к нужному каталогу с именем файла, под которым вы хотите сохранить новый документ.

Сохранение изменений в открытом документа

Сохраняйте изменения в существующем документе с помощью метода Document.Save или параметра SaveChanges метода Document.Close:

‘Сохранение изменений документа

myDocument.Save

‘Сохранение изменений документа

‘при закрытии

myDocument.Close ‘по умолчанию True

myDocument.Close True

myDocument.Close wdSaveChanges

‘Закрытие документа без

‘сохранения изменений

myDocument.Close False

myDocument.Close wdDoNotSaveChanges

Закрытие любого сохраненного документа

Метод Document.Close закрывает документ, но не приложение. Если работа с приложением закончена, оно закрывается с помощью метода Application.Quit.

Millions of small businesses all around the world use Microsoft Word and Excel daily to create correspondence or crunch numbers. If you are like many small business owners, there are probably plenty of times when you have both Excel and Word open at the same time. In fact, copying and pasting data from an Excel spreadsheet into a Word sales letter is a task many business users perform often. While minimizing Excel to open an existing document in Word — or to create a new one — is relatively quick and simple, using Visual Basic for Applications, or VBA, you can program macros or command buttons in Excel that make opening and working with Microsoft Word even faster and more productive.

Enable the Developer Tab

  1. Launch Microsoft Excel on your computer. Click the “File” tab on the ribbon bar, then the “Options” link.

  2. Click the “Customize Ribbon” link on the left side of the Excel Options window. Locate the “Developer” value in the right pane under the “Customize the Ribbon” header. Click the check box next to the “Developer” value label.

  3. Click the “OK” button to save the option changes and return to the main Excel program window. After you return to the main Excel window, the Developer tab appears on the ribbon bar.

Opening an Existing Word Document from Excel

  1. Click the “Developer” tab on the Excel ribbon bar. Click the “Insert” icon on the Developer tab. In the drop-down box, click and select the “Button” control in the Form Controls section.

  2. Click the cell in the Excel spreadsheet where you want the command button control to appear. The Assign Macro window opens automatically.

  3. Type “OpenWordFile” or something similar in the Macro Name field. Be sure not use spaces in the name or the macro won’t save properly. Click the “New Button” in the Assign Macro window. The Microsoft Visual Basic for Applications editor window opens and appears on the screen.

  4. Highlight all of the text in the Book1 – Module1 (Code) window. Press the “Backspace” key to delete all of the text. Copy and paste the following code into the window:

    Sub Open_Word_Document() ‘Open an existing Word Document from Excel Dim objWord As Object Set objWord = CreateObject(«Word.Application») objWord.Visible = True ‘Change the directory path and file name to the location ‘of the document you want to open from Excel objWord.Documents.Open «C:Documentsmyfile.doc» End Sub

  5. Change the “C:Documentsmyfile.doc” value to the complete file path of the existing Word document file you want to open with the command button in Excel. For instance, if the documents resides in the “C:My Document” folder and has the filename “sales letter.docx,” change the value to “C:My Documentssales letter.docx.”

  6. Click the “Save” icon on the Visual Basic editor toolbar. A new Excel “Save As” window appears on the screen.

  7. Enter a new file name for the workbook file in the “File Name” field, then click “Save.” Alternatively, leave the current file name in place, then click the “Save” button.

  8. Click the “Command Button” in the Excel spreadsheet. Microsoft Word opens automatically and displays the file from the path you entered in the Visual Basic editor code window.

Create New Word Document from Excel

  1. Launch Microsoft Excel and click the Developer tab.

  2. Click the “Insert” icon on the Developer tab and select the Button control. Select the cell on your spreadsheet where you want to place the command button.

  3. Create a new macro name called “NewWordDocument” or something similar. Click the “New” button in the Assign Macro window.

  4. Copy and paste the following code into the Visual Basic editor window:

    Sub NewWordDocument() Dim wrdApp As Word.Application Dim wrdDoc As Word.Document Dim i As Integer Set wrdApp = CreateObject(«Word.Application») wrdApp.Visible = True Set wrdDoc = wrdApp.Documents.Add ‘ or ‘Set wrdDoc = wrdApp.Documents.Open(«C:FoldernameFilename.doc») ‘ sample word operations With wrdDoc For i = 1 To 100 .Content.InsertAfter «Here is a sample test line #» & i .Content.InsertParagraphAfter Next i If Dir(«C:DocumentsMyNewWordDoc.doc») <> «» Then Kill «C:DocumentsMyNewWordDoc.doc» End If .SaveAs («C:DocumentsMyNewWordDoc.doc») .Close ‘ close the document End With wrdApp.Quit ‘ close the Word application Set wrdDoc = Nothing Set wrdApp = Nothing End Sub

  5. Save the new macro code in the Visual Basic editor. Save the Excel workbook file when prompted to do so. Close the editor window to return to Excel.

  6. Click the command button you created on the spreadsheet. Microsoft Word opens and displays a new blank document.

 

Здравствуйте, подскажите пожалуйста, какой код VBA нужно написать, чтобы с кнопки ActiveX на листе Excel открывался Word файл. Файл лежит в одной папке с Excel. НО планируется распространить данный файл всем коллегам , поэтому , нужен относительный путь к файлу (то есть путь к файлу будет у каждого человека свой ) ?

Изменено: Владислав Макеев08.09.2022 00:41:14

 

New

Пользователь

Сообщений: 4582
Регистрация: 06.01.2013

#2

08.09.2022 00:56:26

Код
Sub Открыть_Word_Файл()
    Dim myWord As Object, myDocument As Object, WordFileName As String
    
    WordFileName = "Test.docx" 'название файла Word
    Set myWord = CreateObject("Word.Application")
    Set myDocument = myWord.Documents.Open(ThisWorkbook.Path & Application.PathSeparator & WordFileName)
    myWord.Visible = True
End Sub

Изменено: New08.09.2022 00:58:02

 

Владислав Макеев

Пользователь

Сообщений: 8
Регистрация: 08.09.2022

#3

09.09.2022 16:23:42

Цитата
написал:

Код
    [URL=#]?[/URL]       1  2  3  4  5  6  7  8      Sub   Открыть_Word_Файл()          Dim   myWord   As   Object  , myDocument   As   Object  , WordFileName   As   String                   WordFileName =   "Test.docx"   'название файла Word          Set   myWord = CreateObject(  "Word.Application"  )          Set   myDocument = myWord.Documents.Open(ThisWorkbook.Path & Application.PathSeparator & WordFileName)          myWord.Visible =   True    End   Sub   

 

Спасибо огромное ,за такой быстрый ответ!!!Код заработал!!! Но если не сложно сможете подсказать, excel открывает у меня файл, но в свернутом виде , как доработать код так , чтобы он всегда открывался в развернутом виде?  

 

New

Пользователь

Сообщений: 4582
Регистрация: 06.01.2013

#4

09.09.2022 16:35:19

пожалуйста, не нажимайте кнопку Цитировать, я помню, что я писал вам. Нажимайте кнопку «Имя»
попробуйте так

Код
Sub Открыть_Word_Файл()
    
    Dim myWord As Object, myDocument As Object, WordFileName As String
     
    WordFileName = "Test.docx" 'название файла Word
    Set myWord = CreateObject("Word.Application")
    Set myDocument = myWord.Documents.Open(ThisWorkbook.Path & Application.PathSeparator & WordFileName)
    myWord.Visible = True
    myWord.WindowState = xlMaximized
End Sub

Изменено: New10.09.2022 01:14:22

 

Тимофеев

Пользователь

Сообщений: 1497
Регистрация: 01.09.2020

#5

09.09.2022 16:48:57

Код
Sub Открыть_Word_Файл()
    Dim myWord As Object, myDocument As Object, WordFileName As String
     
    WordFileName = "Test.docx" 'название файла Word
    Set myWord = CreateObject("Word.Application")
    Set myDocument = myWord.Documents.Open(ThisWorkbook.Path & Application.PathSeparator & WordFileName)
    myWord.Visible = True
    'myWord.Activate
    myWord.WindowState = 1
End Sub
 

Тимофеев, спасибо за Ваш вариант он мне подошёл, я активировал строчку кода myWord.Active и теперь файл открывается при запуске кнопки! Но вот небольшой вопрос , а если я положу Word файл в отдельную папку, он мне выдаст ошибку , как это поправить?

Изменено: Владислав Макеев10.09.2022 00:35:58

 

добавить в макрос диалог выбора файла

 

New

Пользователь

Сообщений: 4582
Регистрация: 06.01.2013

#8

10.09.2022 01:20:06

Код
Sub Открыть_Word_Файл()
    Dim myWord As Object, myDocument As Object, sPath As String
      
    sPath = Application.GetOpenFilename("Файлы Word (*.doc*),*.doc*", 1, "Выберите файл Word", , False)
    If sPath = "False" Then Exit Sub

    Set myWord = CreateObject("Word.Application")
    Set myDocument = myWord.Documents.Open(sPath)
    myWord.Visible = True
    myWord.WindowState = xlMaximized
End Sub

Изменено: New10.09.2022 01:22:02

 

Александр Моторин, New, Извините что вел вас в заблуждение , но по моему я некорректно выразился. Под словом отдельная папка я имел ввиду , то что файл excel и файл  word лежат в одной папке.И для того чтобы вордовский файл не мешался ,я для него создал отдельную папку там же , по сути файлы находятся рядом. Пример, путь к файлу excel: C:Рабочий столРасчётыРасчёты закупок.xlsx , а путь к вордовскому файлу C:Рабочий столРасчётыПрайсыАктуальный прайс.docx.
Я прошу подсказать как  код из сообщения #5 доработать так, чтобы эксель искал вордовский файл именно в папке «Прайсы» ? Но при этом , как я понимаю ссылка должна быть относительная, то есть ,чтобы эксель не привязывался к определенному пути, так как я собираюсь распространить этот файл своим коллегам ,а у них пути  к файлу будут разные.

Изменено: Владислав Макеев10.09.2022 03:03:55

 

New

Пользователь

Сообщений: 4582
Регистрация: 06.01.2013

#10

10.09.2022 03:06:57

чувствую эта тема будет бесконечной…

Код
Sub Открыть_Word_Файл()
    Dim myWord As Object, myDocument As Object, WordFileName As String
      
    WordFileName = "ПрайсыАктуальный прайс.docx" 'папка и название файла Word
    Set myWord = CreateObject("Word.Application")
    Set myDocument = myWord.Documents.Open(ThisWorkbook.Path & WordFileName)
    myWord.Visible = True
    myWord.Activate
    myWord.WindowState = 1
End Sub
 

New, Тимофеев. Искренне благодарю за плодотворную, качественную работу, выполненную в короткий срок на высоком профессиональном уровне. Это позволило достичь эффективных результатов. Спасибо за проявленные старания, ответственность, добросовестность, трудолюбие, за удачно примененные глубокие знания и огромный практический опыт. Надеюсь на еще более успешную работу в дальнейшем.

Изменено: Владислав Макеев11.09.2022 16:40:23

 

RAN

Пользователь

Сообщений: 7091
Регистрация: 21.12.2012

#12

11.09.2022 19:46:46

Код
Sub qq()
    Dim myDocument As Object, WordFileName As String
    WordFileName = ThisWorkbook.Path & "/Документ Microsoft Word.docx" 'папка и название файла Word
    Set myDocument = GetObject(WordFileName)
    myDocument.Parent.Visible = True
End Sub

Понравилась статья? Поделить с друзьями:
  • Макрос в excel открыть функцию
  • Макрос в word для антиплагиата
  • Макрос в excel открыть файл word
  • Макрос в word 2007 это
  • Макрос в excel лабораторная работа