This is an unofficial api wrapper for TikTok.com in python. With this api you are able to call most trending and fetch specific user information as well as much more.
If you want to use this API as a service visit the RapidAPI
Consider sponsoring me here
- Getting Started
- Quick Start Guide
- Detailed Documentation
- Common Parameters
- TikTok Class
- get_Video_By_TikTok
- bySound
- getUserObject
- getTikTokById
- getTikTokByUrl
- getUser
- getMusicObject
- getHashtagObject
- byUsername
- byHashtag
- discoverMusic
- discoverHashtags
- getSuggestedUsersbyID
- getSuggestedUsersbyIDCrawler
- getSuggestedHashtagsbyID
- getSuggestedHashtagsbyIDCrawler
- getSuggestedMusicbyID
- getSuggestedMusicIDCrawler
- get_Video_By_DownloadURL
- get_Video_By_Url
- get_Video_No_Watermark
- search_for_users
- search_for_music
- search_for_hashtags
- discover_type
- userLiked
- userLikedbyUsername
- TikTokUser Class
- Built With
- Authors
- License
To get started using this api follow the instructions below.
If you run into an issue please check the closed issues on the github. You're most likely not the first person to experience this issue. If nothing works feel free to open an issue.
pip install TikTokApi
python -m playwright install
If you run into any issue try the fix below before posting an issue.
If you still run into issues you may need to install chromedriver for your machine globally. Download it here and add it to your path.
Please don't open an issue if you're experiencing one of these just comment if the provided solution do not work for you.
- Browser object has no attribute verifyFp There's so many issues by this error please search (open and closed) issues before posting
- Browser closed unexpectedly
- BadStatusLine
Here's a quick bit of code to get the most recent trending on TikTok. There's more examples in the examples directory.
from TikTokApi import TikTokApi
api = TikTokApi.get_instance()
results = 10
trending = api.trending(count=results)
for tiktok in trending:
# Prints the id of the tiktok
print(tiktok['id'])
print(len(trending))
To run the example scripts from the repository root, make sure you use the module form of python the interpreter
python -m examples.getTrending
Here's an example of what a tiktok dictionary looks like.
Note: This documentation is called detailed, which it is, but it may be out of date. And if you see something wrong or want to improve the documentation feel free to open a PR with the fixes.
- username - the username of a user you want to find
- secUid - the secUid of the user (you can find in the responses)
- userId / id - The id of the user
- proxy - the proxy address of your proxy
- language - the 2 letter code for your language (this is included in the requests by default to TikTok, but it doesn't seem to do much for me at least)
- language - Ex: en (doesn't seem to change data)
- region - Ex: US (doesn't seem to change data)
TikTokApi(self, debug=False, request_delay=None, executablePath=None)
debug - Enable this if you need some more output.
request_delay - The time to wait in seconds before sending a request.
executablePath - The path to your chromedriver if you don't want global install of chromedriver.
api.trending(self, count=30, referrer="https://www.tiktok.com/@ondymikula/video/6756762109670477061", language='en', proxy=None)
count - this is how many trending Tiktoks you want to be returned.
Trending returns an array of dictionaries. Example structure here
api.get_Video_By_TikTok(data, language='en', proxy=None)
data - The tiktok dictionary returned from the API. Will return bytes.
This method returns an array of tiktoks based on a sound id.
def bySound(self, id, count=30, language='en', proxy=None)
id - the sound's id (you can get this from other methods)
This method returns a user object, primarily used for other methods within the package.
def getUserObject(self, username, language='en', proxy=None)
This object returns a TikTok object when given the TikTok ID.
def getTikTokById(self, id, language='en', proxy=None)
This does the same as the getTikTokById method, but it extracts the id out of the url.
def getTikTokByUrl(self, url, language='en', proxy=None)
This method returns a user object, including all profile data about the user.
def getUser(self, username, language='en', proxy=None)
username - the unique username of the person you want to get an object for.
This method returns a music object, primarily used for other methods within the package.
def getMusicObject(self, id, language='en', proxy=None)
id - the ID of the music.
This method returns a hashtag (challenge) object, primarily used for other methods within the package.
def getHashtagObject(self, hashtag, language='en', proxy=None)
hashtag - the hashtag or challenge name
This method returns an array of tiktoks by a username
def byUsername(self, username, count=30, language='en', proxy=None)
This method returns an array of TikToks by a given hashtag or challenge (without the #)
def byHashtag(self, hashtag, count=30, language='en', proxy=None)
hashtag - a given hashtag or challenge without the #
Returns trending music shown on the side at tiktok's trending page on desktop
def discoverMusic(self, language='en', proxy=None)
Returns trending hashtags (challenges) shown on the side at tiktok's trending page on desktop
def discoverHashtags(self, language='en', proxy=None)
Returns a list of a given user's liked TikToks. Returns a length of 0 if private list.
userLiked(self, userID, secUID, count=30, language='en', region='US', proxy=None)
Returns a list of a given user's liked TikToks. Returns a length of 0 if private list.
userLikedbyUsername(self, username, count=30, proxy=None, language='en', region='US')
This method gets suggested users for a given userid.
getSuggestedUsersbyID(self, count=30, userId='6745191554350760966', language='en', proxy=None)
This method gets users across a variety of userids.
getSuggestedUsersbyIDCrawler(self, count=30, startingId='6745191554350760966', language='en', proxy=None)
This method gets related hashtags given a userid.
getSuggestedHashtagsbyID(self, count=30, userId='6745191554350760966', language='en', proxy=None)
This method crawls across multiple user's profile using the user crawler method to generate hashtags.
getSuggestedHashtagsbyIDCrawler(self, count=30, startingId='6745191554350760966', language='en', proxy=None)
This method gets suggested music given a userId
getSuggestedMusicbyID(self, count=30, userId='6745191554350760966', language='en', proxy=None)
This method crawls across multiple user's profile using the user crawler method to generate music objects.
getSuggestedMusicIDCrawler(self, count=30, startingId='6745191554350760966', language='en', proxy=None)
api.get_Video_By_DownloadURL(url, language='en', proxy=None)
url - The download url that's found in the TikTok dictionary. TikTok['video']['downloadAddr']
api.get_Video_By_Url(video_url, return_bytes=0)
video_url - The video you want to get url.
return_bytes - The default value is 0, when it is set to 1 the function instead returns the bytes from the video rather than just the direct url.
api.get_Video_No_Watermark(video_url, return_bytes=0, language='en', proxy=None)
video_url - The video you want to get url.
return_bytes - The default value is 0, when it is set to 1 the function instead returns the bytes from the video rather than just the direct url.
If you request without bytes you will need to make a call to the URL it responds yourself to get bytes.
url = api.get_Video_No_Watermark_ID('6829267836783971589', return_bytes=0)
import requests
video_bytes = requests.get(url, headers={"User-Agent": "okhttp"}).content
def search_for_users(self, search_term, count=28, **kwargs)
Searches for users given a search term.
def search_for_music(self, search_term, count=28, **kwargs)
Searches for music given a search term
def search_for_hashtags(self, search_term, count=28, **kwargs)
Searches for hashtags given a search term.
discover_type(self, search_term, prefix, count=28, **kwargs)
You can use this method if you really want, but just use the 3 above it.
api.get_Video_No_Watermark_ID(self, video_id, return_bytes=1, proxy=None)
video_id - The video id you want to get.
return_bytes - The default value is 0, when it is set to 1 the function instead returns the bytes from the video rather than just the direct url.
If you request without bytes you will need to make a call to the URL it responds yourself to get bytes.
url = api.get_Video_No_Watermark_ID('6829267836783971589', return_bytes=0)
import requests
video_bytes = requests.get(url, headers={"User-Agent": "okhttp"}).content
api.get_Video_No_Watermark(self, video_url, return_bytes=0, proxy=None)
This endpoint returns a url that is able to be opened in any browser, but sacrifices speed for this convenience. Any old request library can return the bytes if you decide to return a url.
video_url - the url of the video you wish to download
return_bytes - if you want to return bytes or a url
api.getUserPager(username, page_size=30, before=0, after=0)
This endpoint returns a generator, which emits pages of tiktok records posted by the user specified by username
.
The size of the pages can be specified with page_size
. The generator will request the next page
of results
lazily, and terminate once the TikTok api indicates that the feed has been exhausted.
before
and after
are cursor parameters that accept millisecond-precision UNIX timestamps. Note that the generator
does use these values internally to manage paging, but if you pass them in here that will only set their 'starting
points. For after
, that means setting a hard limit on how far back in the user's feed to go, bur before
sets the
starting point for pagination. If they are not passed (or 0 is passed for them), then the pager will be able to
traverse the user's entire feed.
One more note: The pages of results are often one or two records short of the full page_size
specified, even if
there are more results. This doesn't mean that tiktoks are being missed, just that TikTok didn't deign to fill the
page completely.
username - TikTok username for the user from which to request tiktoks
page_size - integer specifying the maximum number of tiktoks to return in a page (default 30)
after - millisecond-precision UNIX timestamp. only tiktoks posted after that time will be retrieved. (default 0)
before - millisecond-precision UNIX timestamp. only tiktoks posted before that time will be retrieved. (default infinity)
api.getHashtagPager(hashtag, page_size=30)
This endpoint returns a generator, which emits pages of tiktok records posted under a given hashtag. The size
of the pages can be specified with page_size
. The generator will request the next page
of results lazily, and
terminate once the TikTok api indicates that the feed has been exhausted.
One more note: The pages of results are often one or two records short of the full page_size
specified, even if
there are more results. This doesn't mean that tiktoks are being missed, just that TikTok didn't deign to fill the
page completely.
hashtag - string representation of the hashtag in question (without the '#' prefix)
page_size - integer specifying the maximum number of tiktoks to return in a page (default 30)
user = TikTokUser(self, user_cookie, debug=False)
user_cookie - The cookie of the logged in user. To get this string log into the desktop site of TikTok and go to the javascript console and type in document.cookie and copy that string and pass it in here.
debug - Enable this if you need some more output.
Will be denoted by user for the methods below
user.get_insights(videoID, username=None)
This endpoint returns a the insights/analytics for a specific TikTok video.
videoID - The id of the TikTok
username - You don't need to provide this, but it's possible TikTok compares the refer header in the future so it's more robust to do this.
- Python 3.7 - The web framework used
- David Teather - Initial work - davidteather
See also the list of contributors who participated in this project.
This project is licensed under the MIT License - see the LICENSE.md file for details