Web应用Word编辑

本例采用的做法是:在后台调用服务器上一个已做好的word模板(含书签),使用word自带的功能对模板的内容进行编辑,完成后将改新的word保存在服务器上(比如MyNew1.doc),客户端再使用一个ocx控件打开服务器上的这个文件MyNew1.doc(也可以用respose方法输出)。

备注:本实例默认模板为:ProjectZJQualityFlow.doc。本使用了ajax方法获取服务器word所在路径,当然也可以使用隐藏域(input type="hidden" )在PageLoad中赋值路径,然后在js中获得隐藏域中的路径值。

cs的一个类:

using System;
using System.Data;
using System.Configuration;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;
using Microsoft.Office;
using Microsoft.Office.Core;
using Microsoft.Office.Interop;
using Microsoft.Office.Interop.Word;
using Microsoft.Office.Tools.Word;

using PinMing.ProjectManage.BLL;
using System.IO;
/// <summary>
/// word模板创建工厂类
/// </summary>
public class ClsWordFactory
{
    /// <summary>
    /// 工程造价咨询word打印模板枚举
    /// </summary>
    public enum WordModelEnum
    {
        /// <summary>
        /// 工程造价咨询质量控制流程单
        /// </summary>
        eProjectZJQualityFlow,

        /// <summary>
        /// 征求意见稿回执单
        /// </summary>
        eSolicitIdeaReturnReceipt

    }
    string path = "Document/"; //ConfigurationManager.AppSettings["UpFilePath"].ToString().Substring(1);
    Microsoft.Office.Interop.Word.Document wDoc = null;
    Microsoft.Office.Interop.Word.Application wApp = null;

    public ClsWordFactory()
    {

    }

    /// <summary>
    /// 创建打印单
    /// </summary>
    /// <param name="wordTypeEnum">工程造价咨询word打印模板枚举</param>
    /// <param name="expertid">项目关键字ID</param>
    public string CreateWord(WordModelEnum wordTypeEnum, string expertid)
    {
        string docUrl = string.Empty;
        switch (wordTypeEnum)
        {
            case WordModelEnum.eProjectZJQualityFlow:

                BLLOrderXYXZ bll = new BLLOrderXYXZ();
                DataTable dt = bll.GetProInfo(expertid).Tables[0];

                docUrl = CreateProjectZJQualityFlow(dt, expertid);
                break;

            case WordModelEnum.eSolicitIdeaReturnReceipt:
                return string.Empty;
                break;
        }
        return docUrl;
    }

    #region 工程造价咨询质量控制流程单

    /// <summary>
    /// 工程造价咨询质量控制流程单
    /// </summary>
    /// <returns></returns>
    private string CreateProjectZJQualityFlow(DataTable projectDt, string expertid)
    {
        string url = HttpContext.Current.Server.MapPath("Templet//ProjectZJQualityFlow.doc");

        this.OpenWordDocument(url, ref wDoc, ref wApp);
        object oEndOfDoc = "\\endofdoc";
        object missing = System.Reflection.Missing.Value;
        int wordEndRowIndex = 4;//添加行的首行号
        //设定书签部分的数据
        SetBookMarkData(wApp, projectDt);

        //设定专业咨询人员
        Microsoft.Office.Interop.Word.Table wordUserTable = wDoc.Tables[1];
        SetUserTableView(wordUserTable, expertid, ref wDoc, ref wApp, ref wordEndRowIndex);

        //收尾工作  
        SetEndPartTableView(wDoc, wApp, ref missing, expertid);

       // return "../Document/OfficeBak" + expertid + ".doc";

        return "WordReport/" + path + "WordPrintBak/" + expertid + ".doc";
    }

    /// <summary>
    /// 设定专业咨询人员
    /// </summary>
    /// <param name="wordTable"></param>
    /// <param name="wDoc"></param>
    /// <param name="WApp"></param>
    /// <returns></returns>
    private bool SetUserTableView(Microsoft.Office.Interop.Word.Table wordTable, string expertid, ref Microsoft.Office.Interop.Word.Document wDoc, ref Microsoft.Office.Interop.Word.Application WApp, ref int startrow)
    {
        BLLOrderXYXZ bll = new BLLOrderXYXZ();
        DataSet cpxx = bll.GetProjectSJRY(expertid);//获取审计人员列表
        if (cpxx == null || cpxx.Tables[0].Rows.Count <= 0)
        {
            return false;
        }

        object Rownum = cpxx.Tables[0].Rows.Count;
        object Columnnum = 1;
        startrow = startrow + 1;//加上标题行
        wordTable.Cell(startrow, 2).Split(ref Rownum, ref Columnnum);
        wordTable.Cell(startrow, 3).Split(ref Rownum, ref Columnnum);
        wordTable.Cell(startrow, 4).Split(ref Rownum, ref Columnnum);

        for (int i = 0; i < cpxx.Tables[0].Rows.Count; i++)
        {
            wordTable.Cell(startrow + i, 2).Range.Text = cpxx.Tables[0].Rows[i]["SJRY"].ToString();
            wordTable.Cell(startrow + i, 3).Range.Text = cpxx.Tables[0].Rows[i]["SUBJECT"].ToString();
            wordTable.Cell(startrow + i, 4).Range.Text = cpxx.Tables[0].Rows[i]["ZYTYPENAME"].ToString();
           
        }
        startrow = startrow + cpxx.Tables[0].Rows.Count;
        return true;
    }

    #endregion

    #region 通用的方法

    /// <summary>
    /// 设定标签数据
    /// </summary>
    /// <param name="application">word的应用</param>
    /// <param name="dt">数据源</param>
    private void SetBookMarkData(Microsoft.Office.Interop.Word.Application application, DataTable dt)
    {

        System.Collections.IEnumerator enu = application.ActiveDocument.Bookmarks.GetEnumerator();
        int len = application.ActiveDocument.Bookmarks.Count;
        string[] strbook = new string[len];//dt.Columns.Count
        int i = 0;
        Microsoft.Office.Interop.Word.Bookmark bk = null;
        while (enu.MoveNext())
        {
            bk = (Microsoft.Office.Interop.Word.Bookmark)enu.Current;

            if (bk.Name.ToString().Trim() != "Table")
            {
                strbook[i] = bk.Name.ToString();
                i++;
            }
        }

        object tempobject = null;
        int length = 0;
        for (i = 0; i < strbook.Length; i++)
        {
            tempobject = strbook[i].ToString();
            if (application.ActiveDocument.Bookmarks.Exists(strbook[i].ToString()))
            {
                application.ActiveDocument.Bookmarks.get_Item(ref tempobject).Select();
                try
                {
                    application.Selection.Text = dt.Rows[0][strbook[i]].ToString();
                }
                catch
                {
                    continue;
                }
            }

        }
    }

    /// <summary>
    /// 收尾工作
    /// </summary>
    /// <param name="document">文档</param>
    /// <param name="application">应用</param>
    /// <param name="missing"></param>
   private void SetEndPartTableView(Microsoft.Office.Interop.Word.Document document, Microsoft.Office.Interop.Word.Application application, ref object missing, string expertid)
    {
        object o = null;
        string directoryUrl = path + "WordPrintBak/";
        directoryUrl = directoryUrl.Replace("\\\\", "\\");

        string directoryUrl2 = HttpContext.Current.Server.MapPath(directoryUrl);
        if (!Directory.Exists(directoryUrl2))    //文件夹不存在 创建它
        {
            Directory.CreateDirectory(directoryUrl2);
        }
        object sFileName = HttpContext.Current.Server.MapPath(directoryUrl + expertid + ".doc");

        if (document.SaveFormat == (int)Microsoft.Office.Interop.Word.WdSaveFormat.wdFormatDocument)
        {
            document.Application.ActiveDocument.SaveAs(ref sFileName, ref missing, ref missing,
            ref missing, ref missing, ref missing,
            ref missing, ref missing,
            ref missing, ref missing,
            ref missing, ref missing, ref missing,
            ref missing, ref missing, ref missing);
        }

        document.Close(ref missing, ref missing, ref missing);
        wApp.Quit(ref missing, ref missing, ref missing);

        if (document != null)
        {
            System.Runtime.InteropServices.Marshal.ReleaseComObject(document);
            document = null;
        }

        if (wApp != null)
        {
            System.Runtime.InteropServices.Marshal.ReleaseComObject(wApp);
            wApp = null;
        }

        GC.Collect();
   }

    /// <summary>
    /// 打开word模板和word文件
    /// </summary>
    /// <param name="fileName">文件名称(模板所在路径)</param>
    /// <param name="document"></param>
    /// <param name="application"></param>
    private void OpenWordDocument(string wordFileName, ref Microsoft.Office.Interop.Word.Document document, ref Microsoft.Office.Interop.Word.Application appliction)
    {
        if (wordFileName == "") return;
        Microsoft.Office.Interop.Word.Document thisDocument = null;
        Microsoft.Office.Interop.Word.FormFields formFields = null;
        //Microsoft.Office.Interop.Word.Application thisApplication = new Microsoft.Office.Interop.Word.Application();//.NET4.0下写法
        Microsoft.Office.Interop.Word.Application thisApplication = new Microsoft.Office.Interop.Word.ApplicationClass(); //.NET2.0下写法
       // thisApplication.Visible = false;
        thisApplication.Caption = "";
        thisApplication.Options.CheckSpellingAsYouType = false;
        thisApplication.Options.CheckGrammarAsYouType = false;

        Object filename = wordFileName;
        Object ConfirmConversions = false;
        Object ReadOnly = true;
        Object AddToRecentFiles = false;

        Object PasswordDocument = System.Type.Missing;
        Object PasswordTemplate = System.Type.Missing;
        Object Revert = System.Type.Missing;
        Object WritePasswordDocument = System.Type.Missing;
        Object WritePasswordTemplate = System.Type.Missing;
        Object Format = System.Type.Missing;
        Object Encoding = System.Type.Missing;
        Object Visible = System.Type.Missing;
        Object OpenAndRepair = System.Type.Missing;
        Object DocumentDirection = System.Type.Missing;
        Object NoEncodingDialog = System.Type.Missing;
        Object XMLTransform = System.Type.Missing;

        try
        {
            Microsoft.Office.Interop.Word.Document wordDoc =
             thisApplication.Documents.Open(ref filename, ref ConfirmConversions,
             ref ReadOnly, ref AddToRecentFiles, ref PasswordDocument, ref PasswordTemplate,
             ref Revert, ref WritePasswordDocument, ref WritePasswordTemplate, ref Format,
             ref Encoding, ref Visible, ref OpenAndRepair, ref DocumentDirection,
             ref NoEncodingDialog, ref XMLTransform);

            thisDocument = wordDoc;
            document = wordDoc;
            appliction = thisApplication;
            formFields = wordDoc.FormFields;
        }
        catch (Exception ex)
        {

        }
    }

    #endregion

}

html代码:

<script>

function OpenFile()
    {
        var url= document.getElementById('hidUrl').value;
        var fileurl='http://'+location.host+ WordReport_WordView.GetDocPath(url).value;
        if(fileurl!='')
            document.getElementById('FramerControl1').Open(fileurl, true);
    }

</script>

<bodyοnlοad="OpenFile()">
    <form id="form1" runat="server">
        <div>

<asp:ScriptManager ID="ScriptManager1" runat="server">
            </asp:ScriptManager>
            <asp:UpdatePanel ID="UpdatePanel1" runat="server">
            </asp:UpdatePanel>

<object id="FramerControl1" codebase="dsoframer.ocx#Version=2,2,0,6" height="550px"
                            width="100%" classid="clsid:00460182-9E5E-11D5-B7C8-B8269041DD57">

</object>

     </table>
        </div>
    </form>
</body>

html下的cs代码:

public partial class WordReport_WordView : System.Web.UI.Page
{
    protected void Page_Load(object sender, EventArgs e)
    {
        AjaxPro.Utility.RegisterTypeForAjax(typeof(WordReport_WordView));
        if (!IsPostBack)
        {
            string id = HttpContext.Current.Request["ID"];
            SetWordPrintContent(id);
        }
    }

    private void SetWordPrintContent(string itemID)
    {
        ClsWordFactory factory = new ClsWordFactory();
       string docUrl= factory.CreateWord(ClsWordFactory.WordModelEnum.eProjectZJQualityFlow, itemID);

       string url = docUrl;
       hidUrl.Value = docUrl;
    
    }

    //返回附件基础路径
    [AjaxPro.AjaxMethod]
    public string GetDocPath(string filepath)
    {
        string SavePath = Server.MapPath(Context.Request.Cookies["GetAppPath"].Value ) +"/"+ filepath;
        SavePath = SavePath.Replace(@"\", @"/").Replace(@"\\\",@"\\");
        return Context.Request.Cookies["GetAppPath"].Value + "/" + filepath;
    }
}

最终效果图:



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
版本修改记录: V2.2.0.2修改: 修改了HttpPost相对路径的一些问题。 V2.2.0.0增加: [id(0x00010041), helpstring("Get Rev Index")] HRESULT GetRevCount( [out,retval] long * pbool); [id(0x00010042), helpstring("Get Rev Index Info")] HRESULT GetRevInfo([in] long lIndex, [in] long lType, [out,retval] BSTR* pbool); [id(0x00010043), helpstring("Set Doc Prop")] HRESULT SetValue([in] BSTR strValue, [in] BSTR strName, [out,retval] long* pbool); [id(0x00010044), helpstring("Set Doc Variable")] HRESULT SetDocVariable([in] BSTR strVarName, [in] BSTR strValue,[in] long lOpt, [out,retval] long* pbool); [id(0x00010045), helpstring("Save page To Doc")] HRESULT SetPageAs([in] BSTR strLocalFile, [in] long lPageNum, [in] long lType,[out,retval] long* pbool); ---------------------------------------------------------------------------------------------------------------------------------------------------------------------- LoadDso.js var s = "" s += "" s += "" document.write(s) ---------------------------------------------------------------------------------------------------------------------------------------------------------------------- 接口文档: /* 1.新建 */ //新建Word document.all.FramerControl1.CreateNew("Word.Document"); //新建Excel document.all.FramerControl1.CreateNew("Excel.Sheet"); /* 2.打开文件 */ //打开制定的本地文件 document.all.FramerControl1.Open("C:\\TestBook.xls"); //制定用Word来打开c:\plain.txt文件 document.all.FramerControl1.Open("C:\\Plain.txt",false, "Word.Document"); //打开服务器的文件 document.all.FramerControl1.Open "https://secureserver/test/mytest.asp?id=123",true, "Excel.Sheet", "MyUserAccount", "MyPassword"); //打开服务器的文件 document.all.FramerControl1.Open("http://localhost/1.doc", true); /* 3.保存文件 */ //到本地 document.all.FramerControl1.Save("c:\\1.doc",true); //服务器 /*增加Http协议Post上传接口,可以Post一个动态页面(jsp,asp,php...),由动态页面负责解析数据 bool HttpInit(); bool HttpAddPostString(BSTR strName, BSTR strValue); bool HttpAddPostCurrFile(BSTR strFileID, BSTR strFileName); BSTR HttpPost(BSTR bstr); */ //初始化Http引擎 document.all.FramerControl1.HttpInit(); //增加Post变量 document.all.FramerControl1.HttpAddPostString("RecordID","20060102200"); document.all.FramerControl1.HttpAddPostString("UserID","李局长"); //上传打开的文件 document.all.FramerControl1.HttpAddPostCurrFile("FileData", "文档名.doc"); //执行上传动作 document.all.FramerControl1.HttpPost("http://xxxx.com/uploadfile.asp"); /* 4.修订留痕 */ //进入留痕状态 document.all.FramerControl1.SetTrackRevisions(1); //进入非留痕状态 document.all.FramerControl1.SetTrackRevisions(0); //接受当前修订 document.all.FramerControl1.SetTrackRevisions(4); /* 5.设置当前用户 */ document.all.FramerControl1.SetCurrUserName("张三"); /* 6.设置当前时间(笔迹留痕会显示("Like 2006:02:07 11:11:11") */ document.all.FramerControl1.SetCurrTime("2006:02:07 11:11:11"); /* 7.设置和创建书签,此功能比较强大,设置书签数据、添加书签和添加红头文件就靠他了 SetFieldValue(BSTR strFieldName, BSTR strValue, BSTR strCmdOrSheetName) strFieldName:书签名 strValue:要设置的值 strCmdOrSheetName: 命令 ::ADDMARK:: 添加BookMark ::DELMARK:: 删除这个BookMark ::GETMARK:: 定位到这个BookMark ::FILE:: 插入的是文件 ::JPG:: 插入的是图片 一般来说:WORD中书签是做好的,可以通过此接口把外界数据设置进书签中去。 */ //在当前WORD位置插入标签,标签名为"book1",数值为"test" document.all.FramerControl1.SetFieldValue("book1","test","::ADDMARK::"); //设置书签"Time",数值为"2006-03-16 22:22:22" document.all.FramerControl1.SetFieldValue("Time","2006-03-16 22:22:22",""); //在书签位置"hongtou",插入红头文件"http://222.222.222.222/hongtou1.doc" 这样,红头就自动插进去了 document.all.FramerControl1.SetFieldValue("hongtou","http://222.222.222.222/hongtou1.doc","::FILE::"); /* 8.设置菜单显示情况 BOOL SetMenuDisplay(long lMenuFlag) lMenuFlag为以下数值的组合 #define MNU_NEW 0x01 #define MNU_OPEN 0x02 #define MNU_CLOSE 0x04 #define MNU_SAVE 0x08 #define MNU_SAVEAS 0x16 #define MNU_PGSETUP 0x64 #define MNU_PRINT 0x256 #define MNU_PROPS 0x32 #define MNU_PRINTPV 0x126 */ //只有“新建”菜单可用 document.all.FramerControl1..SetMenuDisplay(1); //只有“打开”菜单可用 document.all.FramerControl1.SetMenuDisplay(2); //只有“打开”和“新建”菜单可用 document.all.FramerControl1.SetMenuDisplay(3); /* 9.保护文档和解保护文档 lProOrUn:1:保护文档;0:解除保护 lProType: wdNoProtection = -1, wdAllowOnlyRevisions = 0, wdAllowOnlyComments = 1, wdAllowOnlyFormFields = 2 strProPWD:密码 */ //完全保护文档,密码为"pwd" document.all.FramerControl1.ProtectDoc(1,1,"pwd"); //解除文档保护 document.all.FramerControl1.ProtectDoc(0,1,"pwd"); /* 10.显示或隐藏修订内容 ShowRevisions(long nNewValue) nNewValue = 0 则隐藏修订 = 1 则显示修订 */ //显示修订留痕 document.all.FramerControl1.ShowRevisions(1); //隐藏修订留痕 document.all.FramerControl1.ShowRevisions(0); /* 11.插入合并文件, strFieldPath 文件路径,可以是http,ftp的路径 pPos = 0 //当前鼠标位置 1;文件开头 2;文件末尾 pPos的第4位为1的时候,代表插入的是图片 InSertFile(BSTR strFieldPath, long lPos) */ //文件头部插入文件 document.all.FramerControl1.InSertFile("http://XX.com/XX.doc",1); //文件尾部插入文件 document.all.FramerControl1.InSertFile("http://XX.com/XX.doc",2); //当前光标位置插入文件 document.all.FramerControl1.InSertFile("http://XX.com/XX.doc",0); //文件头部插入图片 document.all.FramerControl1.InSertFile("http://XX.com/XX.jpg",9); //文件尾部插入图片 document.all.FramerControl1.InSertFile("http://XX.com/XX.jpg",10); //当前光标位置插入图片 document.all.FramerControl1.InSertFile("http://XX.com/XX.jpg",8); /* 0x31. 文档另存为 HRESULT SaveAs([in] VARIANT strFileName, [in] VARIANT dwFileFormat, [out,retval] long* pbool); 参数: strFileName:文件本地路径,如c:\\11.doc dwFileFormat: 文件格式 dwFileFormat的数值为: Excel: Type enum XlFileFormat { xlAddIn = 18, xlCSV = 6, xlCSVMac = 22, xlCSVMSDOS = 24, xlCSVWindows = 23, xlDBF2 = 7, xlDBF3 = 8, xlDBF4 = 11, xlDIF = 9, xlExcel2 = 16, xlExcel2FarEast = 27, xlExcel3 = 29, xlExcel4 = 33, xlExcel5 = 39, xlExcel7 = 39, xlExcel9795 = 43, xlExcel4Workbook = 35, xlIntlAddIn = 26, xlIntlMacro = 25, xlWorkbookNormal = -4143, xlSYLK = 2, xlTemplate = 17, xlCurrentPlatformText = -4158, xlTextMac = 19, xlTextMSDOS = 21, xlTextPrinter = 36, xlTextWindows = 20, xlWJ2WD1 = 14, xlWK1 = 5, xlWK1ALL = 31, xlWK1FMT = 30, xlWK3 = 15, xlWK4 = 38, xlWK3FM3 = 32, xlWKS = 4, xlWorks2FarEast = 28, xlWQ1 = 34, xlWJ3 = 40, xlWJ3FJ3 = 41, xlUnicodeText = 42, xlHtml = 44 }; Word: Type enum WdSaveFormat { wdFormatDocument = 0, wdFormatTemplate = 1, wdFormatText = 2, wdFormatTextLineBreaks = 3, wdFormatDOSText = 4, wdFormatDOSTextLineBreaks = 5, wdFormatRTF = 6, wdFormatUnicodeText = 7, wdFormatEncodedText = 7, wdFormatHTML = 8 }; PPT: enum PpSaveAsFileType { ppSaveAsPresentation = 1, ppSaveAsPowerPoint7 = 2, ppSaveAsPowerPoint4 = 3, ppSaveAsPowerPoint3 = 4, ppSaveAsTemplate = 5, ppSaveAsRTF = 6, ppSaveAsShow = 7, ppSaveAsAddIn = 8, ppSaveAsPowerPoint4FarEast = 10, ppSaveAsDefault = 11, ppSaveAsHTML = 12, ppSaveAsHTMLv3 = 13, ppSaveAsHTMLDual = 14, ppSaveAsMetaFile = 15, ppSaveAsGIF = 16, ppSaveAsJPG = 17, ppSaveAsPNG = 18, ppSaveAsBMP = 19 }; */ /* 0x32. 删除本地文件 HRESULT DeleteLocalFile([in] BSTR strFilePath); 参数: strFileName:文件本地路径,如c:\\11.doc */ /* 0x33.创建临时文件 HRESULT GetTempFilePath([out,retval] BSTR* strValue); 返回: 临时文件的路径地址。使用完后,用DeleteLocalFile 删除 */ /* 0x34.设置文档显示模式 HRESULT ShowView([in] long dwViewType, [out,retval] long * pbool); dwViewType的可取值为: enum WdViewType { wdNormalView = 1, wdOutlineView = 2, wdPrintView = 3, wdPrintPreview = 4, wdMasterView = 5, //这个是大纲 wdWebView = 6 }; */ //大纲模式 document.all.FramerControl1.ShowView(5); /* 0x39:下载远程文件 HRESULT DownloadFile( [in] BSTR strRemoteFile, [in] BSTR strLocalFile, [out,retval] BSTR* strValue); 参数: strRemoteFile:远程路径地址,http or Ftp strLocalFile: 本地保存地址,if strLocalFile == NULL then Create Temp File and return TempFile's Path */ /* 0x40:增加Http上传时候的,附加其他文件 HRESULT HttpAddPostFile([in] BSTR strFileID, [in] BSTR strFileName, [out,retval] long* pbool); 参数: strFileID:文件的ID,供服务器端页面解析 strFileName: 本地文件地址 */ /* 0x41,0x42.获取详细的修订信息。 GetRevCount( [out,retval] long * pbool); GetRevInfo([in] long lIndex, [in] long lType, [out,retval] BSTR* pbool); 例子如下 */ var vCount; vCount = document.all.FramerControl1.GetRevCount(); alert(vCount); var vOpt = 0; var vDate; for(var i=1; i<= vCount; i++){ vOpt = document.all.FramerControl1.GetRevInfo(i,2); if("1" == vOpt){ vOpt = "插入"; }else if("2" == vOpt){ vOpt = "删除"; }else{ vOpt = "未知操作"; } vDate = new String(document.all.FramerControl1.GetRevInfo(i,1)); vDate = parseFloat(vDate); alert(vDate); dateObj = new Date(vDate); alert(dateObj.getYear() + "年" + dateObj.getMonth() + 1 + "月" + dateObj.getDate() +"日" + dateObj.getHours() +"时" + dateObj.getMinutes() +"分" + dateObj.getSeconds() +"秒" ); alert("用户:"+document.all.FramerControl1.GetRevInfo(i,0) + "\r\n操作:" + vOpt + "\r\n内容:" + document.all.FramerControl1.GetRevInfo(i,3)); } /* 0x43.设置基本信息: HRESULT SetValue([in] BSTR strValue, [in] BSTR strName, [out,retval] long* pbool); 1.设置文件只读密码 SetValue("password","::DOCPROP:PassWord"); 2.设置文件修改密码 SetValue("password","::DOCPROP:WritePW"); 返回值: 0 正确 -1:不支持此命令,请确定您的第二个参数没有传错 -127:异常 */ //设置文件只读密码 document.all.FramerControl1.SetValue("password","::DOCPROP:PassWord"); //设置文件修改密码 document.all.FramerControl1.SetValue("password","::DOCPROP:WritePW"); /* 0x44.设置文档变量,这个很少能用到 HRESULT SetDocVariable([in] BSTR strVarName, [in] BSTR strValue,[in] long lOpt, [out,retval] long* pbool); strVarName: 变量名 strVlaue:变量值 lOpt: 操作类型, 按位 第一位为1: 表示update域关联的 第二位为1: 表示如果没有这个变量则添加 第三位为1: 未来支持 return: 0:OK -127:异常 */ /* 0x45: 分页保存 HRESULT SetPageAs([in] BSTR strLocalFile, [in] long lPageNum, [in] long lType,[out,retval] long* pbool); strLocalFile:本地路径 lPageNum:页数 */

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值