如何解决使用迭代器集合的map函数返回空的迭代器Scala Spark
我有以下案例课。
case class UserEvent(id: Int,url: String)
我有以下符合预期目的的代码。此代码创建3个UserEvents的Iterator对象,然后返回3的长度。
val event1: UserEvent = UserEvent(1,"Url1")
val event2: UserEvent = UserEvent(1,"Url2")
val event3: UserEvent = UserEvent(1,"Url3")
val eventIterator: Iterator[UserEvent] = Iterator(event1,event2,event3)
println(eventIterator.length) //Returns 3
但是,当我尝试映射到该迭代器并仅接收URL时,这将导致一个空的迭代器。例如
val eventUrls: Iterator[String] = eventIterator.map(
userEvent =>{userEvent.url}
)
println(eventUrls.length) //This returns 0
这个简单的示例提供了一些意外的输出。如何使应用于迭代器的映射返回非空的迭代器?
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。