Foxtable(狐表)用户栏目专家坐堂 → 请教版主获取网页数据项目的问题


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

主题:请教版主获取网页数据项目的问题

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


加好友 发短信
等级:三尾狐 帖子:683 积分:4882 威望:0 精华:0 注册:2014/6/15 16:01:00
请教版主获取网页数据项目的问题  发帖心情 Post By:2017/1/11 10:27:00 [只看该作者]

http://youjia.chemcp.com/YuanYouJiaGe.asp

 

想获得油价表格中的数据并保存到“国际市场油价数据表”中

 

 


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

 

参考这个例子:http://www.foxtable.com/bbs/dispbbs.asp?boardid=2&id=49278

 

我做得项目总有错误提示,紧接着我的整个预览窗口都无法关闭了,只能关闭整个进程,并且获取不到任何数据,清版主指导。

 

 


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

 

项目文件:
 

 下载信息  [文件大小:   下载次数: ]
图片点击可在新窗口打开查看点击浏览该文件:原油价格自动获取.foxdb


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


加好友 发短信
等级:三尾狐 帖子:683 积分:4882 威望:0 精华:0 注册:2014/6/15 16:01:00
  发帖心情 Post By:2017/1/11 10:39:00 [只看该作者]

好像web.Document.GetElementById("container")这个也不对,这个数据表没有 ID

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


加好友 发短信
等级:超级版主 帖子:13837 积分:69650 威望:0 精华:0 注册:2016/11/1 14:42:00
  发帖心情 Post By:2017/1/11 10:53:00 [只看该作者]

Dim web As New System.Windows.Forms.WebBrowser()
web.ScriptErrorsSuppressed = True
web.Navigate("http://youjia.chemcp.com/YuanYouJiaGe.asp")

Do Until web.ReadyState = 4
    Application.DoEvents
Loop


'取数据
Dim Cols() As String = { "名称","价格","涨跌额","涨跌幅","发布日期" }

Dim elems As object = web.Document.GetElementsByTagName("table")(5).GetElementsByTagName("tr")
Dim m As Integer = 0
Dim t As Table = Tables("国际市场原油价格表")
For Each elem As object In elems
    Dim i As Integer = -1
    m = m + 1
    If m > 1 Then  '因为网页的表格有标题,如果不判断,就会增加出一个空行
        t.AddNew
    End If
   
    Dim tdelems As object =  elem.GetElementsByTagName("td")
    For Each tdelem As object In tdelems
        i = i + 1
        If t.Cols(i).IsNumeric Then
            t.Current(Cols(i)) = val(tdelem.Innertext.replace("↓", "").replace("↑", "").replace("%", ""))
            t.Current("录入日期") = Date.Today
        Else
            t.Current(Cols(i)) = tdelem.Innertext
            t.Current("录入日期") = Date.Today
        End If
    Next
Next
t.save


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


加好友 发短信
等级:三尾狐 帖子:683 积分:4882 威望:0 精华:0 注册:2014/6/15 16:01:00
  发帖心情 Post By:2017/1/11 11:02:00 [只看该作者]

 有点色版主效率越来越高了。

  顺利获取数据,能把重复的数据删除了吗?如果存在相同的数据,就不再录入相同的了。因为要通过计时器自动获取数据,当前网页上有几天的数据,每天自动检查一遍,如果不剔除重复的数据的话,就会有多条相同的数据(录入时间不同)。
[此贴子已经被作者于2017/1/11 11:07:52编辑过]

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


加好友 发短信
等级:超级版主 帖子:13837 积分:69650 威望:0 精华:0 注册:2016/11/1 14:42:00
  发帖心情 Post By:2017/1/11 11:20:00 [只看该作者]

 获取各列的值,这样写

 

tdelems(0).Innertext

tdelems(1).Innertext

tdelems(2).Innertext

 

 那么,你合并成条件,然后find表格,不就行了?


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


加好友 发短信
等级:三尾狐 帖子:683 积分:4882 威望:0 精华:0 注册:2014/6/15 16:01:00
  发帖心情 Post By:2017/1/11 11:29:00 [只看该作者]

不太明白。你的意思是,判断表格中的数据,包括名称,涨跌额,涨跌幅等,如果存在相同的,然后find?


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


加好友 发短信
等级:超级版主 帖子:13837 积分:69650 威望:0 精华:0 注册:2016/11/1 14:42:00
  发帖心情 Post By:2017/1/11 11:44:00 [只看该作者]

1、请读懂代码;

 

2、直接合成条件查表,如果存在,就不新增数据


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


加好友 发短信
等级:三尾狐 帖子:683 积分:4882 威望:0 精华:0 注册:2014/6/15 16:01:00
  发帖心情 Post By:2017/1/11 11:50:00 [只看该作者]

一会儿测试如下方案是否可行
http://www.foxtable.com/help/index.htm?page=2481.htm

Select Case e.DataCol.name
    Case
 "型号","规格"
        
Dim dr As DataRow = e.DataRow
        
If dr.IsNull("型号") = False AndAlso dr.IsNull("规格") = False Then
            If e.DataTable.Compute("Count([_Identify])","型号 = '" & dr("型号") & "' And 规格 = '" & dr("规格") & "'") > 1 Then
                MessageBox.Show(
"已经存在相同型号和规格的行!","提示",MessageBoxButtons.OK,MessageBoxIcon.Information)
                e.
DataRow(e.DataCol.Name) = e.OldValue '取消输入
            
End If
        End
 If
End
 
Select

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


加好友 发短信
等级:超级版主 帖子:13837 积分:69650 威望:0 精华:0 注册:2016/11/1 14:42:00
  发帖心情 Post By:2017/1/11 11:52:00 [只看该作者]

 你获取数据的时候,不是可以直接查找是否已经存在相同数据吗?判断名称和日期,就行。


 回到顶部
帅哥哟,离线,有人找我吗?
天若千颖
  10楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:三尾狐 帖子:683 积分:4882 威望:0 精华:0 注册:2014/6/15 16:01:00
  发帖心情 Post By:2017/1/11 12:38:00 [只看该作者]

 Select Case e.DataCol.name
    Case "名称","发布日期"
        Dim dr As DataRow = e.DataRow
        If dr.IsNull("名称") = False AndAlso dr.IsNull("发布日期") = False Then
            If e.DataTable.Compute("Count([_Identify])","名称 = '" & dr("名称") & "' And 发布日期 = '" & dr("发布日期") & "'") > 1 Then
                MessageBox.Show("已经存在相同名称和发布日期的行!","提示",MessageBoxButtons.OK,MessageBoxIcon.Information)
                e.DataRow(e.DataCol.Name) = e.OldValue '取消输入
            End If
        End If
End Select

把这个代码直接放在DataChanged中,虽然能投提示已经存在相同的行,但是同样会保存相同的数据。 

Select Case e.DataCol.name
    Case "名称","发布日期"
        Dim xh As String
        Dim gg As String
        If e.DataCol.Name= "名称" Then
            xh = e.NewValue
            gg = e.DataRow("发布日期")
        Else
            gg = e.NewValue
            xh = e.DataRow("名称")
        End If
        If xh > "" AndAlso gg  > "" Then 
            Dim dr As DataRow = e.DataRow
            If e.DataTable.Find("名称 = '" & xh & "' And 发布日期 = '" & gg & "'") IsNot Nothing Then
                MessageBox.Show("已经存在相同名称和发布日期的行!","提示",MessageBoxButtons.OK,MessageBoxIcon.Information)
                e.Cancel = True
            End If
        End If
End Select

把上述代码放在DataChanging中也无效。
[此贴子已经被作者于2017/1/11 12:51:21编辑过]

 回到顶部
总数 22 1 2 3 下一页