0

我是编程新手。我有一个项目,我必须从网站获取数据(我将在下面发布网站)。但碰巧我首先必须选择一个日期并按下“开始”按钮,然后单击另一个按钮/链接“在 Excel 中查看”以下载此数据。在选择所需日期后,我找不到首先单击“开始”按钮,然后通过我的 c# 代码单击第二个按钮“在 Excel 中查看”的方法。任何帮助将不胜感激。

PS:你可以自己查看链接http://www.mcxindia.com/sitepages/BhavCopyDateWiseArchive.aspx

private void Form1_Load(object sender, EventArgs e)
    {
        WebClient webClient = new WebClient();

        byte[] b = webClient.DownloadData("http://www.mcxindia.com/sitepages/BhavCopyDatewise.aspx");

        string s = System.Text.Encoding.UTF8.GetString(b);

        var __EVENTVALIDATION = ExtractVariable(s, "__EVENTVALIDATION");

        //__EVENTVALIDATION.Dump();

        var forms = new NameValueCollection();

        forms["__EVENTTARGET"] = "btnLink_Excel";
        forms["__EVENTARGUMENT"] = "";
        forms["__VIEWSTATE"] = ExtractVariable(s, "__VIEWSTATE");
        forms["mTbdate"] = "01%2F15%2F2013";
        forms["__EVENTVALIDATION"] = __EVENTVALIDATION;

        webClient.Headers.Set(HttpRequestHeader.ContentType, "application/x-www-form-urlencoded");

        var responseData = webClient.UploadValues(@"http://www.mcxindia.com/sitepages/BhavCopyDatewise.aspx", "POST", forms); 
        System.IO.File.WriteAllBytes(@"c:\11152011.csv", responseData);
    }

    private static string ExtractVariable(string s, string valueName)
    {   
        string tokenStart = valueName + "\" value=\"";
        string tokenEnd = "\" />";

        int start = s.IndexOf(tokenStart) + tokenStart.Length;
        int length = s.IndexOf(tokenEnd, start) - start;
        return s.Substring(start, length);
    }

上面的代码只为我提供了最后一个可用日期的文件。我无法在我想要的日期得到它。

4

2 回答 2

1

似乎您需要使用一个发布数据(日期)发出 HTTP Post 请求。这应该很容易。看看这个问题,看看它是否对你有帮助。 通过 ASP.net 发送 HTTP Post 请求

于 2013-02-05T09:44:17.300 回答
0

我找到了这个问题的解决方案。请看这里

于 2013-02-06T13:23:22.057 回答