jjzjj

rss-reader

全部标签

go - 如何将 multipart.File 转换为 io.Reader

也许我只是不明白如何为File对象使用Read方法,但我在文档中看到io.Reader位于multipart.File界面内,但我不明白如何访问它。任何指导将不胜感激。 最佳答案 这意味着multipart.File接口(interface)包含io.Reader接口(interface),因此任何有效的multipart.File对象都是也是一个有效的io.Reader。因此,您可以在multipart.File类型的对象上调用Read方法(由io.Reader定义)。 关于go-如何

io - 如何从 Reader 获取字符串?

这个问题在这里已经有了答案:Fromio.ReadertostringinGo(7个答案)关闭2年前。在strings模块,有一个函数funcNewReader(sstring)*Reader从字符串创建Reader。如何从strings.Reader获取/读取字符串?

go - 为 io.Reader 添加前缀

我编写了一个小型服务器,它以io.Reader的形式接收一团数据,添加一个header并将结果流式传输回调用者。我的实现不是特别有效,因为我在内存中缓冲blob的数据,以便我可以计算blob的长度,这需要构成header的一部分。我看过一些io.Pipe()和io.TeeReader的例子,但它们更适合拆分io.Reader分成两部分,并将它们并行写入。我正在处理的blob大约是100KB,所以不是很大,但是如果我的服务器变得繁忙,内存很快就会成为一个问题...有什么想法吗?funcaddHeader(inio.Reader)(outio.Reader,errerror){buf:=n

golang - 使用 io.Copy 将奇怪的字符从 bufio.Reader 复制到 STDOUT

我有一个应用程序附加到docker容器以使用containerAttach()获取其输出docker库提供的功能。该函数返回HijackedResponse带有指向bufio.Reader的指针的结构。我正在尝试将文本从bufio.Reader流式传输到stdout,并在写入stdout的字符串中获取意外字符。代码:_,err:=io.Copy(os.Stdout,hijackedResponse.Reader)预期输出:RefreshingTerraformstatein-memorypriortoplan...Therefreshedstatewillbeusedtocalcula

http - 将 Reader 返回给 http.Response 的函数

这是我想用于特定页面网络爬虫的代码的精简版。这个想法是有一个获取URL的函数,处理HTTP并将Reader返回到响应主体http.Response:packagemainimport("io""log""net/http""os")funcmain(){consturl="https://xkcd.com/"r,err:=getPageContent(url)iferr!=nil{log.Fatal(err)}f,err:=os.Create("out.html")iferr!=nil{log.Fatal(err)}deferf.Close()io.Copy(f,r)}funcgetP

go - 使用 bufio.reader 从文本文件中读取行

for{v,err=nextNum(reader,'')iferr!=nil{break}w,err=nextNum(reader,'')iferr!=nil{break}cost,err=nextNum(reader,'\n')iferr!=nil{break}fmt.Println(v,w,cost)}我的文本文件由三列和n行组成。第一次调用nextNum时将返回第一行第一列的数字,下次调用第二列第一行的数字,依此类推。我的问题是当我走到最后并最后一次调用nextNum时,我将收到EOF错误并且最后一行永远不会打印出来,因为之前会调用break。关于如何解决问题有什么建议吗?干杯

go - bufio.Reader ReadRune - 大小为 0(返回值)可能吗?

当错误为nil时,ReadRune真的可以返回大小为0的值吗?我很好奇,因为我在网上看到一些例子,代码如下://assuminginput=*bufio.Readerr,size,err:=input.ReadRune()ifsize==0&&err==nil{return0,nil}elseiferr!=nil{return0,err}returnr,nil然而,根据go文档:Iftheencodedruneisinvalid,itconsumesonebyteandreturnsunicode.ReplacementChar(U+FFFD)withasizeof1.那么在什么情况下

python - 当 Reader 类型作为输入时,gzip.NewReader() 返回 nil

我在解压缩之前压缩的字节流时遇到了问题。基本上,我尝试使用函数bytes.NewReader()创建一个阅读器,然后使用gzip.NewReader()函数解压流。最后,我想以字符串或字节格式返回实际值。我知道gzip.NewReader需要io.Reader作为输入,但是,据我所知,类型Reader实现了接口(interface)io.Reader。我认为这不会导致任何错误,但我想知道在这种情况下可能是什么问题。如果你帮我解决这个问题,我将不胜感激!如果您想知道这段文字是什么,"amZzRUR2NHVtcVpiZHNROHJiTTNYeGdUSndGTlVDZC9jaElSK1lXc

go - 从 image.RGBA 实现 io.Reader

我需要一点提示。我正在Go中创建图像的缩略图,并想将它们传递给jpegoptim进行压缩。jpegoptim有--stdin和--stdout标志,我想使用它们。现在,我不想先将生成的图像保存到磁盘,而是将我的*image.RGBA转换为实现io.Reader的东西,这样我就可以将它传递给exec.Cmd.Stdin我对如何实现这一点有些迷茫,如果有人能指出正确的方向,那就太好了。谢谢 最佳答案 在这种情况下,您不需要实现自己的io.Reader。使用io.Pipe和jpeg.Encode,例如funcmain(){//Prepar

go - 在 select 语句中使用 Reader 接口(interface)时的约定

我包装了一个队列来实现Writer和Reader接口(interface)(分别用于推送和弹出)。我需要持续监听队列,并处理通过的每条消息。当队列表示为channel时,这很简单,否则就更难了:loop:for{vardata[]byteselect{case执行此操作的正确方法是什么?Read这里是阻塞的——它一直等到队列有消息。是否有更好、更惯用的方法来实现这一点? 最佳答案 采用同步API(如上面描述的queue.Read)并使其异步比相反的操作更难。我们的想法是创建一个新的goroutine(例如使用gofunc(){...