如何从python脚本运行snscrap命令?

2024-04-20 14:14:04 发布

您现在位置:Python中文网/ 问答频道 /正文

我正在尝试下载一些关于snscrape的推文。安装后,我可以运行如下命令下载一些tweet:

snscrape --jsonl --max-results 4 twitter-search "#SherlockHolmes since:2015-01-01 until:2015-01-15" > sherlock_tweets.json

现在我想在python脚本中运行这个命令。据我所知,实现这一点的方法是使用subprocess.run方法。我使用以下代码从python运行命令:

import subprocess

# Running this in a terminal works
cmd = '''snscrape --jsonl --max-results 4 twitter-search "#SherlockHolmes since:2015-01-01 until:2015-01-15" > sherlock_tweets.json'''
arglist = cmd.split(" ")

process = subprocess.run(arglist, shell=True)

但是,运行此命令会产生以下错误

usage: snscrape [-h] [--version] [-v] [--dump-locals] [--retry N] [-n N] [-f FORMAT | --jsonl] [--with-entity] [--since DATETIME] [--progress]
                {telegram-channel,weibo-user,vkontakte-user,instagram-user,instagram-hashtag,instagram-location,twitter-thread,twitter-search,reddit-user,reddit-subreddit,reddit-search,facebook-group,twitter-user,twitter-hashtag,twitter-list-posts,facebook-user,facebook-community,twitter-profile}
                ...
snscrape: error: the following arguments are required: scraper

为什么这两种情况下的行为不一样?如何从python脚本运行命令,获得与在终端中输入命令完全相同的行为


Tags: 命令searchfacebooktwitterresultsmaxinstagramuntil