文件分部门归类,部门的文件又分一般文件和记录表格小类,文件有文件名称和文件内容组成,全部文件都是WORD文档,
                                    
要求:1、用户可以随时为某个部门添加、删除、修改该部门的文件。当添加一个新的文件名称是,系统应该可以调用WORD给用户编辑然后保存。用户可以根据文件名称查询,然后可以点击该文件名称连接到该文件名称对应的WORD文档,进行修改保存2、可以按照部门为查询条件,列出该部门所有的文件,可以按照部门+文件分类查询列出要查询的文件分类列表,也可以按照部门+文件分类+文件名称模糊查询,可以按照部门+文件名称模糊查询,用户可以点击某文件浏览该文件的内容(浏览该文件的WORD文档)。

解决方案 »

  1.   

    一、Delphi程序启动Word
    采用CreateOleObjects的方法来启动Word,调用VBA代码,具体实现过程为:
    首先使用GetActiveOleObject('Word.Application')判断当前内存中是否存在Word程序,如果存在,
    则直接连接,如果没有Word程序,则使用CreateOleObject('Word.Application')启动Word二、Delphi程序新建Word文稿
    格式:WordDocuments.Add(Template,NewTemplate,DocumentType,Visible)
    Template: 使用模板的名称,
    NewTemplate: 新建文档的类型,True表示为模板,False表示为文档
    DocumentType: 文档类型,默认为空白文档
    Visible: 打捞的窗口是否可见举例:Doc_Handle:=Word_Ole.Documents.Add(Template:='C:\Temlate.dot',NewTemplate:=False);三、Delphi程序打开Word文稿
    格式:WordDocuments.Open(FileName,ConfirmConversions,ReadOnly,PassWordDocument,
                             PasswordTemplate,Revent,WritePasswordDocument,WritePassWordTemplate,
                             Format,Encoding,Visible)FileName: 文档名(包含路径)
    Confirmconversions: 是否显示文件转换对话框
    ReadOnly: 是否以只读方式打开文档
    AddToRecentFiles: 是否将文件添加到"文件"菜单底部的最近使用文件列表中
    PassWordDocument: 打开此文档时所需要的密码
    PasswordTemplate: 打开此模板时所需要的密码
    Revert: 如果文档已经,是否重新打开文档
    WritePasswordDocument: 保存对文档更改时所需要的密码
    WritePasswordTemplate: 保存对模板进行更改时所需要的密码
    Format: 打开文档时所需使用的文件转换器
    Encoding: 所使用的文档代码页
    Visible: 打开文档的窗口是否可见举例:
    Doc_Handle:=Word_Ole.Documents.open(FileName:=Doc_File,ReadOnly:=False,
                AddToRecentFiles:=False);四、Delphi程序保存Word文稿
    格式:WordDocuments.SaveAs(FileName, FileFormat, LockComments, Password,
                              AddToRecentFiles, WritePassword, ReadOnlyRecommended, 
                              EmbedTrueTypeFonts, SaveNativePictureFormat, SaveFormsData, 
                              SaveAsAOCELetter)FileName:              文件名。默认为当前文件夹和文件名。
    FileFormat              文档保存的格式。
    LockComments            如果为 True,则此文档只允许进行批注。
    Password                打开文档时的口令。
    AddToRecentFiles        如果为True,则将文档添至"文件"菜单中最近使用的文档列表中。
    WritePassword           保存对文档的修改所需的口令。
    ReadOnlyRecommended     如果为 True,在每次打开文档时,Word 将建议用户采用只读方式。
    EmbedTrueTypeFonts      如果为 True,则将文档与 TrueType 字体一起保存。
    SaveNativePictureFormat 如果为 True,则从其他系统平台(例如 Macintosh)导入的图形仅保存其 Windows 版本。
    SaveFormsData           如果为 True,则将窗体中用户输入的数据存为一条数据记录。
    SaveAsAOCELetter        如果文档包含一个附加,当此属性值为 True 时,将文档存为一篇 AOCE 信笺(同时保存邮件)。举例:
    Word_Ole.Documents.SaveAs(FileName:=Doc_File,FileFormat=wdFormatDocument,
                              AddToRecentFiles=False);五、从数据库读取文件到本地硬盘和从本地硬盘读取文件到数据库在数据库上使用Image二进制字段保存,使用Stream流的方式。创建文件流:
         Word_FileStream:=TFileStream.Create(Target_Name,fmOpenWrite or fmCreate);
         Word_FileStream.Position:=0;保存到数据库的Image字段:
         TBlobField(AdoQuery1.FieldByName(Column_Name)).SaveToStream(Word_FileStream);从数据库读取文件到本地硬盘:
         TBlobField(ADOQuery1.FieldByName(Column_Name)).loadfromStream(Word_FileStream);释放文件流:
         Word_FileStream.Free;
      

  2.   

    多谢esu(ESU) ,你的例子很详细!
      

  3.   

    我也尝试用流的方法解决,但我不能多次进行文件的写入,而且我想在该表新建一个主码,但这样就插入不成功。我的代码如下
    OpenDialog1.Filter:='WORD文档(*.DOC)|*.DOC';{从对话窗选择文件}   if OpenDialog1.Execute then   begin     MyFile:=TFileStream.Create(OpenDialog1.FileName,fmOpenRead); //找出要写入数据库的WORD文件    with table1 do   {‘table1’为含BLOB字段的表名}     begin       Open;       Edit;       Stream := TBlobStream.Create(FieldByName('Doc') as TBlobField, bmWrite );{‘Doc’为BLOB字段名}       MemSize := MyFile.Size;       Inc(MemSize); {Make room for the  buffer's null terminator.}       Buffer := AllocMem(MemSize);       {Allocate the memory.}       try         Stream.Seek(0, soFromBeginning);  {Seek 0 bytes from the stream's end point}         MyFile.Read(Buffer^,MemSize); //将数据从流读出        Stream.Write(Buffer^,MemSize);       finally         MyFile.Free;         Stream.Free;       end;            try             Post;            except             on E: EDatabaseError do          if HandelException(E)< >0 then                         exit         else         raise;            end;      end;
      

  4.   

    另外,我也考虑了这种方法:
    在服务器中新建一个固定的文件夹,该固定文件夹是共享的,而且该固定文件夹下只可以新建文件夹,不可以放文件,然后在这些新建的文件夹放WORD文件,即第三级才具体到WORD文件。那么可以通过文件夹的名称来索引该文件夹的文件名称,利用FINDFIRST函数可以列出给定的文件夹下的WORD文件的文件名称,然后用ShellExecute函数打开指定的WORD文件。
    但当中我遇到一个问题,就是在DELPHI中我不知道如何登陆到服务器(已经知道密码和用户名称),如果我事先用网上邻居来登陆一次服务器的,那么我的程序就可以打开服务器的WORD文件,否则就打不开。