Foxtable(狐表)用户栏目专家坐堂 → 图片列批量下载的问题


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

主题:图片列批量下载的问题

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


加好友 发短信
等级:小狐 帖子:364 积分:3491 威望:0 精华:0 注册:2012/7/24 7:15:00
图片列批量下载的问题  发帖心情 Post By:2022/8/27 16:17:00 [只看该作者]

在打印隐患排查报告中设置了两个图片列:

图片点击可在新窗口打开查看此主题相关图片如下:1.jpg
图片点击可在新窗口打开查看
但在打印的时候,会出现图片列未加载上的情况。

图片点击可在新窗口打开查看此主题相关图片如下:2.jpg
图片点击可在新窗口打开查看
加了一个按钮,设置了如下代码:
Dim ftp As new ftpclient
ftp.host= "***"
ftp.Account = "***"
ftp.password = "***"
ftp.Port = "21"
ftp.UTF8 = False
Dim curtable As Table = CurrentTable
'Dim cr As Row = curtable.Current
For Each dr As DataRow In DataTables("隐患排查整改报告").Select("[选择] = true")
    Dim 默认目录 As String  = "\" & dr("企业名称") & "\" & dr("年度") & "\" & curtable.Name
    'output.show(默认目录)
    If ftp.DirExists(默认目录) = False Then
        ftp.MakeDir("\" & dr("企业名称"))
        ftp.MakeDir("\" & dr("企业名称") & "\" & dr("年度"))
        If ftp.MakeDir(默认目录) = False Then
            MessageBox.Show("创建目录失败")
            Return
        End If
    End If
    Dim path1 As String = ProjectPath & "RemoteFiles\" & dr("企业名称") & "\" & dr("年度") & "\" & "隐患排查治理台账\" & FileSys.GetName(dr("隐患照片"))
    ftp.Download(dr("隐患照片"), path1, True)
    Dim path2 As String = ProjectPath & "RemoteFiles\" & dr("企业名称") & "\" & dr("年度") & "\" & "隐患排查治理台账\" & FileSys.GetName(dr("验证照片"))
    ftp.Download(dr("验证照片"), path2, True)
Next
ftp.Close

现在存在的问题是:
报错:

图片点击可在新窗口打开查看此主题相关图片如下:微信截图_20220827153726.jpg
图片点击可在新窗口打开查看


请老师帮忙看一下,代码如何修改?谢谢了!

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


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

Dim ftp As New ftpclient
ftp.host = "***"
ftp.Account = "***"
ftp.password = "***"
ftp.Port = "21"
ftp.UTF8 = False

Dim 默认目录 As String = ProjectPath & "RemoteFiles\" & dr("企业名称") & "\" & dr("年度") & "\隐患排查治理台账\"
If FileSys.DirectoryExists(默认目录) = False Then
    If FileSys.CreateDirectory(默认目录) = False;se Then
        MessageBox.Show("创建目录失败")
        Return
    End If 
End If 
For Each dr As DataRow In DataTables("隐患排查整改报告").Select("[选择] = true")
    Dim path1 As String = 默认目录 & FileSys.GetName(dr("隐患照片"))
    ftp.Download(dr("隐患照片"), path1, True)
    Dim path2 As String = 默认目录 & FileSys.GetName(dr("验证照片"))
    ftp.Download(dr("验证照片"), path2, True)
Next
ftp.Close


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


加好友 发短信
等级:小狐 帖子:364 积分:3491 威望:0 精华:0 注册:2012/7/24 7:15:00
  发帖心情 Post By:2022/8/27 20:13:00 [只看该作者]

报了个错;

图片点击可在新窗口打开查看此主题相关图片如下:微信截图_20220827201216.jpg
图片点击可在新窗口打开查看


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


加好友 发短信
等级:小狐 帖子:364 积分:3491 威望:0 精华:0 注册:2012/7/24 7:15:00
  发帖心情 Post By:2022/8/28 9:36:00 [只看该作者]

自己改了一下,麻烦蓝老师看一下,有没有问题:
Dim ftp As New ftpclient
ftp.host = "**"
ftp.Account = "***"
ftp.password = "***"
ftp.Port = "21"
ftp.UTF8 = False
For Each dr As DataRow In DataTables("隐患排查整改报告").Select("[选择] = true")
    Dim 默认目录 As String = ProjectPath & "RemoteFiles\" & dr("企业名称") & "\" & dr("年度") & "\隐患排查治理台账\"
    If FileSys.DirectoryExists(默认目录) = False Then
        FileSys.CreateDirectory(默认目录)
    End If
    If dr.isnull("隐患照片") Then
        MessageBox.Show("    部分行缺少隐患照片,请先上传隐患照片!")
        Return
    Else
        Dim path1 As String = 默认目录 & FileSys.GetName(dr("隐患照片"))
        ftp.Download(dr("隐患照片"), path1, True)
    End If
    If dr.isnull("验证照片") Then
        MessageBox.Show("    部分行缺少验证照片,请先上传验证照片!")
        Return
    Else
        Dim path2 As String = 默认目录 & FileSys.GetName(dr("验证照片"))
        ftp.Download(dr("验证照片"), path2, True)
    End If
Next
ftp.Close

[此贴子已经被作者于2022/8/28 9:38:43编辑过]

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


加好友 发短信
等级:超级版主 帖子:110574 积分:562760 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2022/8/28 20:21:00 [只看该作者]

if DataTables("隐患排查整改报告").compute("count(选择)",[选择] = true and (隐患照片 is null or 验证照片 is null)") > 0 then
        MessageBox.Show("    部分行缺少隐患照片或者验证照片,请先上传照片!")
        Return
end if

Dim ftp As New ftpclient
ftp.host = "**"
ftp.Account = "***"
ftp.password = "***"
ftp.Port = "21"
ftp.UTF8 = False
For Each dr As DataRow In DataTables("隐患排查整改报告").Select("[选择] = true")
    Dim 默认目录 As String = ProjectPath & "RemoteFiles\" & dr("企业名称") & "\" & dr("年度") & "\隐患排查治理台账\"
    If FileSys.DirectoryExists(默认目录) = False Then
        FileSys.CreateDirectory(默认目录)
    End If
        Dim path1 As String = 默认目录 & FileSys.GetName(dr("隐患照片"))
        ftp.Download(dr("隐患照片"), path1, True)
        Dim path2 As String = 默认目录 & FileSys.GetName(dr("验证照片"))
        ftp.Download(dr("验证照片"), path2, True)
Next
ftp.Close

 回到顶部