gpt4 book ai didi

java - 如何在我的 Hadoop Mapper 中将 String 转换为 Writable 对象

转载 作者:可可西里 更新时间:2023-11-01 16:22:37 25 4
gpt4 key购买 nike

几个小时以来,这是一个非常疯狂的问题。

如有任何帮助,我们将不胜感激。

我不能

public void map(Object key, Text value, Context context) throws IOException, InterruptedException {
if (!value.toString().equals("")) {



Gson gson = new Gson();
Boolean flag = true;
System.out.println("000000000");
while(flag){
Text tweetId = new Text();
Tweet tweet = gson.fromJson(value.toString(), Tweet.class);
tweetId.set(tweet.getRetweetStatus().getUser().getId().toString());
System.out.println("Tweet objects:" + tweet.toString());
System.out.println("ParentUserId:" + tweetId);
context.write(tweetId, tweet);
flag = false;
}
Text tweetId = new Text();
Tweet tweet = gson.fromJson(value.toString(), Tweet.class);
tweetId.set(tweet.getUser().getId().toString());
String tweetReverse = (Object) tweet.getRetweetStatus().getUser().getId();

System.out.println("Reverse::");
System.out.println("Tweet objects:" + tweetReverse);
System.out.println("ParentUserId:" + tweetId);

context.write(tweetId, tweetReverse);
}
}

我想将字符串对象“tweetReverse”转换为 Writable,以便我可以在 context.write 函数中使用它。

这可能吗?

转化不成怎么办?

如果我将泛型类型更改为 String,那么在将 Writable 扩展为读取和写入值的类中也会出现问题。

如有任何帮助,我们将不胜感激。

非常感谢。

最佳答案

我觉得你所需要的只是

context.write(tweetId, new Text(tweetReverse));

也就是说,您只需创建一个新的 Text 对象(它实现了 Writable)并在构造函数中传递一个 String。

关于java - 如何在我的 Hadoop Mapper 中将 String 转换为 Writable 对象,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26769412/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com