LinqToTwitter获得转发状态



我正在使用LinqToTwitter API,并遇到以下问题。

如果我(当前用户)已经转发了一条推文,尽管我可以更改ToggleButton上的IsChecked属性以进行转发,但我如何获取信息。

我已经试着获取一个状态的所有推文,将其与我转发的推文ID列表进行比较。

var publicTweets = await (from tweet in TweetContent.Connection.Status
                          where tweet.Type == StatusType.Retweets &&
                                tweet.ID == TweetID
                          select tweet)
                          .ToListAsync();
foreach (var publicTweet in publicTweets)
{
    foreach (var myTweet in TweetContent.AllMyReTweets)
    {
        if (publicTweet.ID == myTweet)
        {
            // false means the ToggleButton is PreSet
            RetweetState = false;
            break;
        }
    }
}
// No hit
RetweetState = true;

还有推特内容。AllMyRetweets的定义如下:

 List<ulong> myList = new List<ulong>();
 var myRetweets = await (from retweet in TweetContent.Connection.Status
                         where retweet.Type == StatusType.RetweetsOfMe &&
                               retweet.Count == 100
                         select retweet)
                         .ToListAsync();
if (myRetweets != null)
{
    foreach (var tweet in myRetweets)
    {
        myList.Add(tweet.ID);
    }
}

我认为这个解决方案有两个问题:

  1. 它为我想要显示的每条推文调用一个API,这意味着它可能需要很多时间。

  2. 我会很快得到一个"超过利率限制"的例外,这告诉我这不可能是正确的方式

最好的方法是什么?

这比我想象的要容易:-)

该信息位于属性Status.Retweeted中的每个Status中,但不会在默认的seath查询(如:)之后填充

 var tweets = Enumerable.FirstOrDefault(
                                from tweet in TweetContent.Connection.Search
                                where tweet.Type == SearchType.Search &&
                                    tweet.Query == query &&
                                    tweet.IncludeEntities == true &&
                                    tweet.Count == maxNumberToFind && (tweet.MaxID == id)
                                select tweet);

在此之后,您必须使用刚刚收到的tweetIDList进行查找查询。这将用正确的值填充属性Status.Retweeted

        List<Status> tweets =
        await
        (from tweet in TweetContent.Connection.Status
         where tweet.Type == StatusType.Lookup &&
               tweet.TweetIDs == tweetIDList
         select tweet)
        .ToListAsync();
        return tweets;

最新更新