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 { | public class YoutubeChannelInfoItemExtractor implements ChannelInfoItemExtractor { | ||||||
|     private final JsonObject channelInfoItem; |     private final JsonObject channelInfoItem; | ||||||
|  |     /** | ||||||
|  |      * New layout: | ||||||
|  |      * "subscriberCountText": Channel handle | ||||||
|  |      * "videoCountText": Subscriber count | ||||||
|  |      */ | ||||||
|  |     private final boolean withHandle; | ||||||
| 
 | 
 | ||||||
|     public YoutubeChannelInfoItemExtractor(final JsonObject channelInfoItem) { |     public YoutubeChannelInfoItemExtractor(final JsonObject channelInfoItem) { | ||||||
|         this.channelInfoItem = 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 |     @Override | ||||||
|  | @ -78,6 +95,11 @@ public class YoutubeChannelInfoItemExtractor implements ChannelInfoItemExtractor | ||||||
|                 return -1; |                 return -1; | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|  |             if (withHandle) { | ||||||
|  |                 return Utils.mixedNumberWordToLong(getTextFromObject( | ||||||
|  |                         channelInfoItem.getObject("videoCountText"))); | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|             return Utils.mixedNumberWordToLong(getTextFromObject( |             return Utils.mixedNumberWordToLong(getTextFromObject( | ||||||
|                     channelInfoItem.getObject("subscriberCountText"))); |                     channelInfoItem.getObject("subscriberCountText"))); | ||||||
|         } catch (final Exception e) { |         } catch (final Exception e) { | ||||||
|  | @ -88,7 +110,7 @@ public class YoutubeChannelInfoItemExtractor implements ChannelInfoItemExtractor | ||||||
|     @Override |     @Override | ||||||
|     public long getStreamCount() throws ParsingException { |     public long getStreamCount() throws ParsingException { | ||||||
|         try { |         try { | ||||||
|             if (!channelInfoItem.has("videoCountText")) { |             if (withHandle || !channelInfoItem.has("videoCountText")) { | ||||||
|                 // Video count is not available, channel probably has no public uploads. |                 // Video count is not available, channel probably has no public uploads. | ||||||
|                 return ListExtractor.ITEM_COUNT_UNKNOWN; |                 return ListExtractor.ITEM_COUNT_UNKNOWN; | ||||||
|             } |             } | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue