fix: #976 search subscriber count extraction with channel handles
This commit is contained in:
parent
c953e23414
commit
5daabd1793
1 changed files with 23 additions and 1 deletions
|
@ -34,9 +34,26 @@ import static org.schabi.newpipe.extractor.services.youtube.YoutubeParsingHelper
|
|||
|
||||
public class YoutubeChannelInfoItemExtractor implements ChannelInfoItemExtractor {
|
||||
private final JsonObject channelInfoItem;
|
||||
/**
|
||||
* New layout:
|
||||
* "subscriberCountText": Channel handle
|
||||
* "videoCountText": Subscriber count
|
||||
*/
|
||||
private final boolean withHandle;
|
||||
|
||||
public YoutubeChannelInfoItemExtractor(final JsonObject channelInfoItem) {
|
||||
this.channelInfoItem = channelInfoItem;
|
||||
|
||||
boolean wHandle = false;
|
||||
try {
|
||||
final String subscriberCountText = getTextFromObject(
|
||||
channelInfoItem.getObject("subscriberCountText"));
|
||||
if (subscriberCountText != null) {
|
||||
wHandle = subscriberCountText.startsWith("@");
|
||||
}
|
||||
} catch (final ParsingException ignored) {
|
||||
}
|
||||
this.withHandle = wHandle;
|
||||
}
|
||||
|
||||
@Override
|
||||
|
@ -78,6 +95,11 @@ public class YoutubeChannelInfoItemExtractor implements ChannelInfoItemExtractor
|
|||
return -1;
|
||||
}
|
||||
|
||||
if (withHandle) {
|
||||
return Utils.mixedNumberWordToLong(getTextFromObject(
|
||||
channelInfoItem.getObject("videoCountText")));
|
||||
}
|
||||
|
||||
return Utils.mixedNumberWordToLong(getTextFromObject(
|
||||
channelInfoItem.getObject("subscriberCountText")));
|
||||
} catch (final Exception e) {
|
||||
|
@ -88,7 +110,7 @@ public class YoutubeChannelInfoItemExtractor implements ChannelInfoItemExtractor
|
|||
@Override
|
||||
public long getStreamCount() throws ParsingException {
|
||||
try {
|
||||
if (!channelInfoItem.has("videoCountText")) {
|
||||
if (withHandle || !channelInfoItem.has("videoCountText")) {
|
||||
// Video count is not available, channel probably has no public uploads.
|
||||
return ListExtractor.ITEM_COUNT_UNKNOWN;
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue