C#下载指定url到本地临时文件,返回对应文件流

读取在线excel文件内容到datatable中,通过下载在线excel到本地临时文件,读取临时文件的文件流,使用所获得的流经过Excel的帮助类获取全部Excel内容

  • 文件转文件流方法
        /// <summary>
        /// 文件转流
        /// </summary>
        /// <param name="fileName">文件路径</param>
        /// <param name="isDelete">是否删除临时文件</param>
        /// <returns></returns>
        private static Stream GetFileStream(string fileName, bool isDelete = false)
        {
            //打开文件
            using (FileStream fileStream = new FileStream(fileName, FileMode.Open, FileAccess.Read, FileShare.Read))
            {   
                // 读取文件的 byte[]
                byte[] bytes = new byte[fileStream.Length];
                fileStream.Read(bytes, 0, bytes.Length);
                fileStream.Close();
                // 把 byte[] 转换成 Stream
                Stream stream = new MemoryStream(bytes);
                if (isDelete)
                {
                    File.Delete(fileName);//删除临时文件
                }
                return stream;
            }
        }
  • 下载文件指定url到本地临时文件
        /// <summary>
        /// 下载指定url到本地临时文件
        /// </summary>
        /// <param name="url"></param>
        /// <returns></returns>
        private static Stream FileDownload(string url)
        {
            using (var client = new System.Net.WebClient())
            {
                string tempFile = Path.GetTempFileName();
                client.DownloadFile(url, tempFile);
                return GetFileStream(tempFile, true);
            }
        }
  • 单元测试读取Excel内容
        [TestMethod]
        public void TestMethod2()
        {
            var filePath = @"http://xxxxxxx.xlsx";
            var stream = FileDownload(filePath);
            var dt = NPOIHelper.ImportExceltoDt(stream, false);
            Assert.Fail();
        }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

大大黑眼圈

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值