S
STeve
Hey guys,
I currently have a 100 page word document filled with various
"articles". These articles are delimited by the Style of the text
(IE. Heading 1 for the various titles) These articles will then be
converted into HTML and saved. I want to write a parser through
vb.net that uses the word object model and was wondering how this
could be achieved? The problem i am running into is that i can not
test whether the selected text is of a certain style. My code so far
in vb.net:
Dim dc As Word.Document
Dim w As Word.Application
w = New Word.Application()
Dim arguments As [String]() = Environment.GetCommandLineArgs()
dc = w.Documents.Open("c:\static\test.doc")
w.Visible = True
w.Selection.EndKey(Word.WdUnits.wdStory)
w.Selection.HomeKey(Word.WdUnits.wdStory,
Word.WdKey.wdKeyShift)
Dim count As Integer
count = w.Selection.Range.ComputeStatistics(Word.WdStatistic.wdStatisticLines)
Dim i As Integer
For i = 0 To 2
w.Selection.HomeKey(Word.WdUnits.wdLine)
If w.Selection.Style = "Heading 3" Then
MsgBox("heading 1")
End If
w.Selection.MoveDown(Word.WdUnits.wdLine, 1)
Next
I currently have something like this in a macro in the word document,
note this is just a prototype, saveHTML simply copies and pastes the
selected text from one document to a new document and saves that
content as an HTML file due to the fact that microsoft word is unable
to "save to html" highlighted selections:
Sub ParseDocument()
Selection.HomeKey Unit:=wdStory
Selection.EndKey Unit:=wdStory
Selection.HomeKey Unit:=wdStory, Extend:=wdExtend
count1 = Selection.Range.ComputeStatistics(Statistic:=wdStatisticLines)
For x = 0 To count1
Selection.HomeKey Unit:=wdLine
If Selection.Style = "Heading 3" Then
saveHTML (file)
ElseIf Selection.Style = "Heading 2" Then
Selection.EndKey Unit:=wdLine, Extend:=wdExtend
z = Selection.Text
End If
If Selection.Style = "Heading 1" Then
file = path + y
saveHTML (file)
Selection.EndKey Unit:=wdLine, Extend:=wdExtend
y = Selection.Text
y = Replace(y, Chr(10), "")
y = Replace(y, Chr(13), "")
y = Replace(y, Chr(12), "")
y1 = y
End If
Selection.MoveDown Unit:=wdLine, count:=1
Next
file = path + y
saveHTML (file)
End Sub
Any help is appreciated, thanks guys
Steve
I currently have a 100 page word document filled with various
"articles". These articles are delimited by the Style of the text
(IE. Heading 1 for the various titles) These articles will then be
converted into HTML and saved. I want to write a parser through
vb.net that uses the word object model and was wondering how this
could be achieved? The problem i am running into is that i can not
test whether the selected text is of a certain style. My code so far
in vb.net:
Dim dc As Word.Document
Dim w As Word.Application
w = New Word.Application()
Dim arguments As [String]() = Environment.GetCommandLineArgs()
dc = w.Documents.Open("c:\static\test.doc")
w.Visible = True
w.Selection.EndKey(Word.WdUnits.wdStory)
w.Selection.HomeKey(Word.WdUnits.wdStory,
Word.WdKey.wdKeyShift)
Dim count As Integer
count = w.Selection.Range.ComputeStatistics(Word.WdStatistic.wdStatisticLines)
Dim i As Integer
For i = 0 To 2
w.Selection.HomeKey(Word.WdUnits.wdLine)
If w.Selection.Style = "Heading 3" Then
MsgBox("heading 1")
End If
w.Selection.MoveDown(Word.WdUnits.wdLine, 1)
Next
I currently have something like this in a macro in the word document,
note this is just a prototype, saveHTML simply copies and pastes the
selected text from one document to a new document and saves that
content as an HTML file due to the fact that microsoft word is unable
to "save to html" highlighted selections:
Sub ParseDocument()
Selection.HomeKey Unit:=wdStory
Selection.EndKey Unit:=wdStory
Selection.HomeKey Unit:=wdStory, Extend:=wdExtend
count1 = Selection.Range.ComputeStatistics(Statistic:=wdStatisticLines)
For x = 0 To count1
Selection.HomeKey Unit:=wdLine
If Selection.Style = "Heading 3" Then
saveHTML (file)
ElseIf Selection.Style = "Heading 2" Then
Selection.EndKey Unit:=wdLine, Extend:=wdExtend
z = Selection.Text
End If
If Selection.Style = "Heading 1" Then
file = path + y
saveHTML (file)
Selection.EndKey Unit:=wdLine, Extend:=wdExtend
y = Selection.Text
y = Replace(y, Chr(10), "")
y = Replace(y, Chr(13), "")
y = Replace(y, Chr(12), "")
y1 = y
End If
Selection.MoveDown Unit:=wdLine, count:=1
Next
file = path + y
saveHTML (file)
End Sub
Any help is appreciated, thanks guys
Steve