Foxtable(狐表)用户栏目专家坐堂 → [求助]doc文字和图片提取


  共有4105人关注过本帖树形打印复制链接

主题:[求助]doc文字和图片提取

帅哥哟,离线,有人找我吗?
miaoqingqing
  1楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:三尾狐 帖子:660 积分:5180 威望:0 精华:0 注册:2019/7/26 12:54:00
[求助]doc文字和图片提取  发帖心情 Post By:2022/4/1 12:41:00 [只看该作者]

 下载信息  [文件大小:   下载次数: ]
图片点击可在新窗口打开查看点击浏览该文件:提取文字图片到表a.zip


求助表a导入外部文档的文字、图片到第一列、第二列(图片保存在Attachments文件夹)

 回到顶部
帅哥哟,离线,有人找我吗?
有点蓝
  2楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:109489 积分:557107 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2022/4/1 13:34:00 [只看该作者]

参考

http://www.foxtable.com/bbs/dispbbs.asp?BoardID=2&ID=71352&skin=0


 回到顶部
帅哥哟,离线,有人找我吗?
miaoqingqing
  3楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:三尾狐 帖子:660 积分:5180 威望:0 精华:0 注册:2019/7/26 12:54:00
回复:(有点蓝)参考http://www.foxtable.com/bbs/di...  发帖心情 Post By:2022/4/1 13:58:00 [只看该作者]

就是看到蓝主上楼你发的这个项目,不知道怎么修改,才求助
上楼项目是从表里面提取,不懂怎么修改
Dim dlg As new OpenFileDialog
dlg.MultiSelect = True
If dlg.ShowDialog = DialogResult.OK Then
    Dim app As New MSWord.Application
    try
        If FileSys.DirectoryExists(ProjectPath & "Attachments") = False Then
            FileSys.CreateDirectory(ProjectPath & "Attachments/")
        End If
        For Each filename As String In dlg.FileNames
           
            Dim doc = app.Documents.Open(fileName)
            Dim nr As Row = Tables("表A").AddNew
            Dim t = doc.Tables(1)
            Dim text = t.Cell(1, 2).Range.Text.ToString()
            text = text.Substring(0, text.Length - 2)
            nr("第一列") = text
            '-------------
            app.ActiveWindow.Selection.WholeStory
            For Each shape As object In app.ActiveWindow.Selection.InlineShapes
                If shape.Type = MSWord.WdInlineShapeType.wdInlineShapePicture
                    Dim img As Byte() = shape.Range.EnhMetaFileBits
                    Dim bmp As new Bitmap(new IO.MemoryStream(img))
                    bmp.Save(ProjectPath & "Attachments/" & nr("第二列") & ".jpg")
                End If
            Next
            nr("第一列") = nr("第二列") & ".jpg"
            Doc.Close
        Next
    catch ex As exception
        msgbox(ex.message)
    finally
        app.Quit
    End try
End If

 回到顶部
帅哥哟,离线,有人找我吗?
有点蓝
  4楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:109489 积分:557107 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2022/4/1 14:23:00 [只看该作者]

Dim dlg As new OpenFileDialog
If dlg.ShowDialog = DialogResult.OK Then
    Dim app As New MSWord.Application
    try
        If FileSys.DirectoryExists(ProjectPath & "Attachments") = False Then
            FileSys.CreateDirectory(ProjectPath & "Attachments/")
        End If
        Dim doc = app.Documents.Open(dlg.FileName)
        Dim nr As Row = Tables("表A").AddNew
        For Each k As object In doc.Paragraphs
            nr("第一列") = nr("第一列")  & k.Range.text
        Next
        'nr("第一列") = text
        '-------------
        Dim lst As new List(of String)
        app.ActiveWindow.Selection.WholeStory
        For Each shape As object In app.ActiveWindow.Selection.InlineShapes
            If shape.Type = MSWord.WdInlineShapeType.wdInlineShapePicture
                Dim img As Byte() = shape.Range.EnhMetaFileBits
                Dim bmp As new Bitmap(new IO.MemoryStream(img))
                Dim f As String = format(Date.now,"yyyyMMddHHmmssfffff") & ".jpg"
                bmp.Save(ProjectPath & "Attachments/" & f)
                lst.add(f)
            End If
        Next
        nr.DataRow.Lines("第二列") =  lst
        Doc.Close
    catch ex As exception
        msgbox(ex.message)
    finally
        app.Quit
    End try
End If

 回到顶部
帅哥哟,离线,有人找我吗?
miaoqingqing
  5楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:三尾狐 帖子:660 积分:5180 威望:0 精华:0 注册:2019/7/26 12:54:00
回复:(有点蓝)Dim dlg As new OpenFileDialogIf dl...  发帖心情 Post By:2022/4/1 16:47:00 [只看该作者]

蓝主,求助,提取的图片放在,姓名,这个文件夹里面

 下载信息  [文件大小:   下载次数: ]
图片点击可在新窗口打开查看点击浏览该文件:提取文字图片到表a - w.foxdb


 回到顶部
帅哥哟,离线,有人找我吗?
有点蓝
  6楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:109489 积分:557107 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2022/4/1 16:49:00 [只看该作者]

保存到哪里自己改保存的路径即可

bmp.Save("保存的路径比如c:\abc\abc.jpg")

 回到顶部
帅哥哟,离线,有人找我吗?
miaoqingqing
  7楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:三尾狐 帖子:660 积分:5180 威望:0 精华:0 注册:2019/7/26 12:54:00
回复:(有点蓝)保存到哪里自己改保存的路径即可bmp....  发帖心情 Post By:2022/4/1 17:00:00 [只看该作者]




 bmp.Save(ProjectPath & "Attachments\"  & nr("姓名") &   f)  

上面代码,提取的图片,放在Attachments的1级文件夹里面不是想要的效果。

想实现,提取的图片,放在Attachments 下面的2级文件夹里面 (当前行 姓名,这个文件夹),下面代码报错:未将对象引用设置到对象的实例
  bmp.Save(ProjectPath & "Attachments\"  & nr("姓名") & "\"  &  f)  
[此贴子已经被作者于2022/4/1 17:00:14编辑过]

 回到顶部
帅哥哟,离线,有人找我吗?
有点蓝
  8楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:109489 积分:557107 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2022/4/1 17:04:00 [只看该作者]

参考:http://www.foxtable.com/webhelp/topics/0332.htm

4楼代码也有CreateDirectory的用法,自己参考创建目录

 回到顶部