Access911.net   |   a9BBS   |   OTaA System  
  搜索文章:  
Access911欢迎您光临  
   主页      上传      繁體版       论坛     
设为首页  |  加入收藏   
  
你现在的位置:文章索引 -> 文章分类 -> 报表  
 首页|  近日更新|  下载  |  文章索引  |  搜索|  术语|  承接工程|  
 
系统正在加载内容,请耐心等待...
 
 查询
 窗体
 报表
 
 
 VBA
 函数
 ADO/DAO/ADO.NET
 API
 ADP
 安全
 发布
 OA
 ASP/ASP.NET
 其他语言
 控件
 DELPHI
 C#/.Net
 本站
 其他
 小例程
 常用软件
 参考文档
 业主作品
 网友大作
 
 
友情链接
 access911.net
 
访问人次
 1702321
 
站长 E-Mail
 net911@sina.com
 access911@gmail.com
 
RSS 订阅

显示附加信息 >>>

以文字(路径)方式保存文件名的图片如何在报表中预览?

作者:cg1  摘自:access911.net  :cg1  更新日期:2003-12-26  浏览人次:

 

问题:


报表中如何预览图片?

数据库表中存放着下面几个字段,学号,姓名,性别,图片路径,如下:1002003001,张三,男,100\2003\1002003001.jpg。现在做报表,想把图片显示出来,因为图片路径为字符类型,所以显示出来的是100\2003\1002003001.jpg,怎样做能把图片显示出来?图片就在数据库所在目录下的100\2003\的文件夹下。

 

回答:

在报表中放置不可见的TEXTBOX,显示图片文件的路径,然后放一个PICTURE控件,在主体的格式化事件里面写代码进行控制。
Private Sub 主体_Format(Cancel As Integer, FormatCount As Integer)
    Image40.Picture = CurrentProject.path & "\" & 照片.Value
End Sub


实例请参考:http://access911.net/down/eg/report_picture.rar
(41.9K)

 

问题:

用了上述代码,为什么有时候预览报表的时候会提示:运行时错误:..... 无法打开文件 ..... ?

 

回答:

存放照片路径的字段值错误,是 NULL 或者在硬盘上不能找到对应的照片文件。需要用 DIR 函数预先判断以后再显示,但是 DIR 只能做简单的判断,遇到文件夹与文件名正好同名的情况就不好判断了。以下是我的解决方案:

Private Sub 主体_Format(Cancel As Integer, FormatCount As Integer)
    '注意,别小看了加载一幅照片呀,这里要考虑很多情况
    '1,“照片”这个字段根本是NULL或者"",空的
    '2,“照片”字段虽然正确,但是照片文件根本不存在或者没有权限读取
    '3,“照片”文件虽然存在,但是根本不是ACCESS能解析的图片

    Dim strPic As String
    strPic = CurrentProject.path & "\" & Nz(照片.Value, "")     '处理为 NULL 的情况
    If ExistsFile_UseFso(strPic) = True Then                    '判断是否存在
        On Error Resume Next
        Image40.Picture = strPic
        If Image40.Picture <> strPic Then                       '判断是否能解析
            Image40.Visible = False
            Label41.Visible = True
        Else
            Image40.Visible = True
            Label41.Visible = False
        End If
    Else
        Image40.Visible = False
        Label41.Visible = True
    End If
End Sub


'===========================================================
' 过程及函数名:  ExistsFile_UseFso
' 版本号      :  1.0
' 说明        :  调用 FSO 检测某个文件是否存在
' 引用        :  Scripting.FileSystemObject
' 输入参数    :  strPath,文本,需要检测的文件名及路径
' 输出值      :  --
' 返回值      :  Boolean,True 表示文件存在;
'                          False 表示文件不存在
' 调用演示    :  ExistsFile_UseFso("c:\boot.ini")
' 最后修改日期:  2007-7-19 17:22:00
' 示例地址    :  http://access911.net/?kbid;72FAB21E17DCECF3
' 作者        :  cg1
' 网站        :  http://access911.net
' 电子邮件    :  access911@gmail.com
' 版权        :  作者保留一切权力,
'                 请在公布本代码时将本段说明一起公布,谢谢!
'===========================================================

Function ExistsFile_UseFso(strPath As String) As Boolean
    Dim fso
    Set fso = CreateObject("Scripting.FileSystemObject")
    ExistsFile_UseFso = fso.FileExists(strPath)
    Set fso = Nothing
End Function


示例下载:
http://access911.net/down/eg/eg_ReportPicture2.rar
 (56KB)

 

本站文章旨在为该问题提供解决思路及关键性代码,并不能完成应该由网友自己完成的所有工作,请网友在仔细看文章并理解思路的基础上举一反三、灵活运用。

access911.net 原创文章,作者本人对文章保留一切权利。
如需转载必须征得作者同意并注明本站链接

 

 
相关文章
     没有手动相关文章
     在子窗体中预览报表
     如何将动态生成的ADO RECORDSET对象绑定到ACCESS报表?
     如何让 ACCESS 2000 支持弹出式报表?(思路及实现)
     在窗体的图片控件中,如何指定只显示我选定的图片的某个区域?
     新手来看:如何将窗体得筛选条件应用在对应得报表中?如何打印当前记录?如何打印指定记录?
     新手来看:如何屏蔽Access的启动图片?
     如何制作复杂报表——利用Excel输出复杂报表
     数据库与图片或者文件的关系如何处理?
 
评论
     查看或发表更多的评论,请单击这里。
 
 
 
 
 
   
  Access911.net   |   a9BBS   |   OTaA System   |
建站日期:2000年4月2日  |  设计施工:陈格 ( access911 & cg1 )
 Copyright © 2000 - 2003 COMET, 陈格 保留所有权利