Форум программистов, компьютерный форум, киберфорум
Visual Basic .NET
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
5 / 3 / 0
Регистрация: 11.03.2013
Сообщений: 42
1

Запись данных м MSWord

29.10.2024, 11:32. Показов 398. Ответов 2
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Добрый день.
Подскажите пожалуйста, как мне записать свои данные в середину документа из внешнего приложения. Я пользуюсь вот этим:
WDoc.Range(SetPos, SetPos + 1).Text = text1
Если документ новый, то все норм, а если нет и допустим мне надо записать данные в середину документа, то все что находится ниже моего диапазона стирается. Как мне сделать чтобы информация сохранялась?
И еще, подскажите пожалуйста, может кто сталкивался, я из внешнего приложения получаю активный документ MS Word. Я могу получить текущую позицию курсора (SetPos)?
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
29.10.2024, 11:32
Ответы с готовыми решениями:

Запись данных в таблицу MSWord
Нужно сделать так: Имеется поле в него заносим имя фамилию и отчество. В второе поле заносим дату...

Delphi. Импорт данных из БД в MsWord
Имеется DBGrid с соответствующей таблицей подключенной с помощью дата модуля. Суть не в этом. Кроме...

Перенос данных из отчета в MSWord
Доброго времени суток! В программировании VB я не силен, и по этой причине прошу Вашей помощи в...

Добавляю запись в БД. Результат: в базу данных добавляется запись с ID=0
Не пойму что за дела.Подскажите где ошибка , заранее спасибо! <?php ...

C# и MSWord
День добрый! Кто знает как отображать окно WORDa у себя на форме, по типу OLE-контейнера в Delphi?

2
4665 / 3620 / 856
Регистрация: 02.02.2013
Сообщений: 3,490
Записей в блоге: 2
29.10.2024, 16:02 2
захаров Максим, например
VB.NET
1
2
3
4
5
6
7
8
9
10
11
12
13
Imports WRD = Microsoft.Office.Interop.Word
Public Class Form1
    Private wApp As WRD.Application
    Private Sub Button1_Click(sender As Object, e As EventArgs) Handles Button1.Click
        wApp = New WRD.Application
        wApp.DisplayAlerts = WRD.WdAlertLevel.wdAlertsNone
        wApp.Visible = True
        Dim objDoc As WRD.Document = wApp.Documents.Open(IO.Path.Combine(Application.StartupPath, "WrdTest1.doc"))
        Dim rng As WRD.Range = objDoc.Range(0, 300)
        Dim str As String = vbCrLf & "qwert asdf ghhjjj" & vbCrLf & "z123456 789654" & vbCrLf
        rng.InsertAfter(str)
    End Sub
End Class
Добавлено через 30 минут
Цитата Сообщение от захаров Максим Посмотреть сообщение
И еще, подскажите пожалуйста, может кто сталкивался, я из внешнего приложения получаю активный документ MS Word. Я могу получить текущую позицию курсора (SetPos)?
VB.NET
1
2
3
Dim Word = GetObject(, "Word.Application")
Dim rng = Word.Selection
MsgBox(rng.start.ToString & vbCrLf & rng.end)
Добавлено через 30 минут
Тоже для Interop.Word
VB.NET
1
2
3
4
Dim wordApp As WRD.Application
wordApp = CType(System.Runtime.InteropServices.Marshal.GetActiveObject("Word.Application"), Microsoft.Office.Interop.Word.Application)
Dim rng = wordApp.Selection
MsgBox(rng.Start.ToString & vbCrLf & rng.End.ToString)
0
5 / 3 / 0
Регистрация: 11.03.2013
Сообщений: 42
30.10.2024, 10:54  [ТС] 3
Подскажите, а что у меня не правильно?
VB.NET
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
Dim WApp As Word.Application = CreateObject("Word.Application")
                                Dim WDoc As Word.Document = Nothing
                                Dim boolWDVisibl As Boolean = False
                                If FormReport.RadioButton3.Checked = True And FormReport.ComboBox1.Text Like "Новый файл docx" Then
                                    WDoc = WApp.Documents.Add()
                                Else
                                    Dim WordObj As Microsoft.Office.Interop.Word.Application = New Microsoft.Office.Interop.Word.Application()
                                    Try
                                        WordObj = System.Runtime.InteropServices.Marshal.GetActiveObject("Word.Application")
                                        If IsNothing(WordObj) = False Then
                                            For i As Integer = 0 To WordObj.Windows.Count - 1
                                                Dim idx As Object = i + 1
                                                Dim WinObj As Word.Window = WordObj.Windows.Item(idx)
                                                If WinObj.Document.Name Like FormReport.ComboBox1.Text Then
                                                    WDoc = WordObj.Documents.Item(idx)
                                                    Exit For
                                                End If
                                            Next
                                        End If
                                    Catch ex As COMException
                                    End Try
                                End If
                                boolWDVisibl = True
                                WApp.Visible = True
                                Dim rng = WDoc.Selection
 
                                MsgBox(rng.start.ToString & vbCrLf & rng.end)
Ошибка в строке Dim rng = WDoc.Selection. Такого метода нет вообще, но прога компилируется, однако затем выходит ошибка

Добавлено через 12 минут
Прошу прощения, кучу "косяков" исправил. Все работает, спасибо
'\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\
'Word документ
VB.NET
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
Dim WApp As Word.Application = Nothing
                                Dim WDoc As Word.Document = Nothing
                                Dim boolWDVisibl As Boolean = False
                                If FormReport.RadioButton3.Checked = True And FormReport.ComboBox1.Text Like "Новый файл docx" Then
                                    WApp = CreateObject("Word.Application")
                                    WDoc = WApp.Documents.Add()
                                    WApp.Visible = True
                                Else
                                    'Dim WordObj As Microsoft.Office.Interop.Word.Application = New Microsoft.Office.Interop.Word.Application()
                                    WApp = New Microsoft.Office.Interop.Word.Application()
                                    Try
                                        WApp = System.Runtime.InteropServices.Marshal.GetActiveObject("Word.Application")
                                        If IsNothing(WApp) = False Then
                                            For i As Integer = 0 To WApp.Windows.Count - 1
                                                Dim idx As Object = i + 1
                                                Dim WinObj As Word.Window = WApp.Windows.Item(idx)
                                                If WinObj.Document.Name Like FormReport.ComboBox1.Text Then
                                                    WDoc = WApp.Documents.Item(idx)
                                                    Exit For
                                                End If
                                            Next
                                        End If
                                    Catch ex As COMException
                                    End Try
                                End If
                                boolWDVisibl = True
                                Dim rng = WApp.Selection
                                MsgBox(rng.Start.ToString & vbCrLf & rng.End)
Добавлено через 1 час 8 минут
Спасибо, текст я вставил в середину документа.
Подскажите пожалуйста, а как таблицу вставить?
VB.NET
1
WDocTbl = WDoc.Tables.Add(range, 3, 5, Word.WdDefaultTableBehavior.wdWord9TableBehavior, Word.WdAutoFitBehavior.wdAutoFitContent)
Я вставляю вот так, опять все что ниже таблицы удаляется...
0
30.10.2024, 10:54
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
30.10.2024, 10:54
Помогаю со студенческими работами здесь

Отчет В MSWord
Подскажите пожалуйста. Делаю отчет в Word-e с помощью шаблона. Мне необходимо добавлять к третьей...

Отчет в MSWord???
Создавал отчет в Access обычный, для перевода его в ворд надо нажать кнопочку на панели...

VBA in MSWord
Всем привет. помогите с этими задачами. Очень надо Создать Макрос (один) для текстового...

MsWord из Delphi
Сталкнулся с такой проблеммой.. Дан Договор (3 страницы) в котором нужно автоматизированно бросить...

Импорт в MSWord
всем здравствуйте! нужно вывести отчет в Word. Имеется набор данных Будем считать (DBGrid1) ,...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru