高难度啊,各位老大:能把rtf格式转换为html吗

html-css013

高难度啊,各位老大:能把rtf格式转换为html吗,第1张

将RTF格式转换成普通的word格式方法如下:

启动word软件,打开rtf格式的文档,按下键盘F12,弹出另存为对话框,选择格式.doc或.docx格式,就实现了将rtf格式转换成普通的word格式。

将RTF格式的文件转成HTML并在网页中显示的代码 它是这样工作的,将一个RTF文件上传,然后转成HTML显示出来,代码有点复杂,teaman还要好好研究,好象中文版有点问题。 <html><body><? if(!($userfile)) { ?><form enctype="multipart/form-data" action="<?print($PHP_SELF)?>" method=post><input type=hidden name="max_file_size" value=2000>Send this file: <input name=userfile type=file><input type=submit value=Upload></form></body></html><? exit} function ProcessTags($tags, $line) { $html = ""global $colorglobal $sizeglobal $bullets// Remove spaces. $tags = trim($tags)// Found the beginning of the bulleted l // ist. if(ereg("\\\pnindent", $tags)) { $html .= "<ul><li>"$bullets += $line$tags = ereg_replace("\\\par", "", $tags)$tags = ereg_replace("\\\(tab)", "", $tags)} if($line - $bullets == 0) { $tags = ereg_replace("\\\par", "", $tags)} elseif($line - $bullets == 1) { if(ereg("\\\pntext", $tags)) { $html .= "<li>"$tags = ereg_replace("\\\par", "", $tags)$tags = ereg_replace("\\\(tab)", "", $tags)$bullets++} else { $html .= "</ul>"$bullets = 0} } // Convert Bold. if(ereg("\\\b0", $tags)){ $html .= "</b>"} elseif(ereg("\\\b", $tags)) { $html .= "<b>"} // Convert Italic. if(ereg("\\\i0", $tags)){ $html .= "</i>"} elseif(ereg("\\\i", $tags)) { $html .= "<i>"} // Convert Underline. if(ereg("\\\ulnone", $tags)){ $html .= "</u>"} elseif(ereg("\\\ul", $tags)){ $html .= "<u>"} // Convert Alignments. if(ereg("\\\pard\\\qc", $tags)) { $html .= "<div align=center>"} elseif(ereg("\\\pard\\\qr", $tags)) { $html .= "<div align=right>"} elseif(ereg("\\\pard", $tags)){ $html .= "<div align=left>"} // Remove \pard from the tags so it does // n't get confused with \par. $tags = ereg_replace("\\\pard", "", $tags)// Convert line breaks. if(ereg("\\\par", $tags)){ $html .= "<br>"} // Use the color table to capture the fo // nt color changes. if(ereg("\\\cf[0-9]", $tags)) { global $fcolor$numcolors = count($fcolor)for($i = 0$i <$numcolors$i++) { $test = "\\\cf" . ($i + 1)if(ereg($test, $tags)) { $color = $fcolor[$i]} } } // Capture font size changes. if(ereg("\\\fs[0-9][0-9]", $tags, $temp)) { $size = ereg_replace("\\\fs", "", $temp[0])$size /= 2if($size <= 10) { $size = 1} elseif($size <= 12) { $size = 2} elseif($size <= 14) { $size = 3} elseif($size <= 16) { $size = 4} elseif($size <= 18) { $size = 5} elseif($size <= 20) { $size = 6} elseif($size <= 22) { $size = 7} else{ $size = 8} } // If there was a font color or size cha // nge, change the font tag now. if(ereg("(\\\cf[0-9])||(\\\fs[0-9][0-9])", $tags)) { $html .= "</font><font size=$size color=$color>"} // Replace \tab with alternating spaces // and nonbreakingwhitespaces. if(ereg("\\\(tab)", $tags)) { $html .= ""} return $html} function ProcessWord($word) { // Replace \\ with \ $word = ereg_replace("[\\]{2,}", "\\", $word)// Replace \{ with { $word = ereg_replace("[\\][\{]", "\{", $word)// Replace \} with } $word = ereg_replace("[\\][\}]", "\}", $word)// Replace 2 spaces with one space. $word = ereg_replace(" ", " ", $word)return $word} $color = "000000"$size = 1$bullets = 0// Read the uploaded file into an array. // $rtfile = file($userfile)$fileLength = count($rtfile)// Loop through the rest of the array for($i = 1$i <$fileLength$i++) { /* ** If the line contains "\colortbl" then we found the color table. ** We'll have to split it up into each individual red, green, and blue ** Convert it to hex and then put the red, green, and blue back together. ** Then store each into an array called fcolor. */ if(ereg("^\{\\\colortbl", $rtfile[$i])) { // Split the line by the backslash. $colors = explode("\\", $rtfile[$i])$numOfColors = count($colors)for($k = 2$k <$numOfColors$k++) { // Find out how many different colors th // ere are. if(ereg("[0-9]+", $colors[$k], $matches)) { $match[] = $matches[0]} } // For each color, convert it to hex. $numOfColors = count($match)for($k = 0$k <$numOfColors$k += 3) { $red = dechex($match[$k])$red = $match[$k] <16 ? "0$red" : $red$green = dechex($match[$k + 1])$green = $match[$k +1] <16 ? "0$green" : $green$blue = dechex($match[$k + 2])$blue = $match[$k + 2] <16 ? "0$blue" : $blue$fcolor[] = "$red$green$blue"} $numOfColors = count($fcolor)} // Or else, we parse the line, pulling o // ff words and tags. else { $token = ""$start = 0$lineLength = strlen($rtfile[$i])for($k = 0$k <$lineLength$k++) { if($rtfile[$i][$start] == "\\" &&$rtfile[$i][$start + 1] != "\\") { // We are now dealing with a tag. $token .= $rtfile[$i][$k]if($rtfile[$i][$k] == " ") { $newFile[$i] .= ProcessTags($token, $i)$token = ""$start = $k + 1} elseif($rtfile[$i][$k] == "\n") { $newFile[$i] .= ProcessTags($token, $i)$token = ""} } elseif($rtfile[$i][$start] == "{") { // We are now dealing with a tag. $token .= $rtfile[$i][$k]if($rtfile[$i][$k] == "}") { $newFile[$i] .= ProcessTags($token, $i)$token = ""$start = $k + 1} } else { // We are now dealing with a word. if($rtfile[$i][$k] == "\\" &&$rtfile[$i][$k + 1] != "\\" &&$rtfile[$i][$k - 1] != "\\") { $newFile[$i] .= ProcessWord($token)$token = $rtfile[$i][$k]$start = $k} else { $token .= $rtfile[$i][$k]} } } } } $limit = sizeof($newFile)for($i = 0$i <$limit$i++) { print("$newFile[$i]\n")} ?></body></html>

不行的话试试这个

{

//创建一个word的实例

Word.Application newApp = new Word.Application()

// 指定源文件和目标文件

object Source="c:\\abc\\Source.doc"

object Target="c:\\abc\\Target.rtf"

object Unknown =Type.Missing

// 打开要转换的Word文件

newApp.Documents.Open(ref Source,ref Unknown,

ref Unknown,ref Unknown,ref Unknown,

ref Unknown,ref Unknown,ref Unknown,

ref Unknown,ref Unknown,ref Unknown,

ref Unknown )

// 指定文档的类型

object format = Word.WdSaveFormat.wdFormatRTF

//改变文档类型

newApp.ActiveDocument.SaveAs(ref Target,ref format,

ref Unknown,ref Unknown,ref Unknown,

ref Unknown,ref Unknown,ref Unknown,

ref Unknown,ref Unknown,ref Unknown)

//关闭word实例

newApp.Quit(ref Unknown,ref Unknown,ref Unknown)

}

}

}

或是这种方法

在richtohtml函数中增加下面的代码就行了:

Dim strLastFontsize As Long

If strLastFontsize <>rtbRichTextBox.SelFontSize Then

strLastFontsize = rtbRichTextBox.SelFontSize

strHTML$ = strHTML$ + "<font-size=""" &strLastFontsize &""">"

End If

新建vb工程

添加引用

Microsoft Word 11.0 Object Library

根据你电脑上word版本的不同,这个组件的版本号可能不一样

添加控件

对话框Microsoft Common Dialog Control 6.0

Microsoft Rich TextBox Control 6.0(sp4),如果你的VB版本更高,这个的版本也可能不一样

然后添加两个RichTextBox和两个按钮,添加一个对话框

复制以下代码

Private Sub Command2_Click()

On Error GoTo ERRPROC

Dim x As Word.Application

Set x = New Word.Application

x.Visible = True

x.ChangeFileOpenDirectory App.Path

x.Documents.Add

With x.ActiveDocument

Clipboard.Clear

Clipboard.SetText RichTextBox1.TextRTF, vbCFRTF

.Content.Paste

Clipboard.Clear

.SaveAs "tmp.html", wdFormatFilteredHTML, False, "", False, "", False, False, False, False, False

x.Quit

Set x = Nothing

End With

RichTextBox2.LoadFile App.Path &"\tmp.html"

Exit Sub

ERRPROC:

MsgBox Err.Number &vbCrLf &Err.Description

End Sub

Private Sub Command1_Click()

CommonDialog1.filename = ""

CommonDialog1.Filter = "RichTextFile(*.rtf)|*.rtf|Word File(*.doc)|*.doc"

CommonDialog1.ShowOpen

If CommonDialog1.filename <>"" Then RichTextBox1.LoadFile CommonDialog1.filename

End Sub

Private Sub Command3_Click()

On Error Resume Next

End Sub

Private Sub Form_Load()

On Error Resume Next

Dim x As Word.Application

Set x = New Word.Application

If Err.Number = 429 Then

MsgBox "您的系统未正确安装ms word!", vbCritical, "ERROR"

End

End If

x.Quit

Set x = Nothing

Command1.Caption = "打开"

Command2.Caption = "保存为HTML并显示"

Command3.Caption = "在浏览器中打开" '这个没做,自己搞了

End Sub