🤖 A simple Android Vitals scraper
# Install
npm i -g vitals-scraper
# Run
vitals-scraper --accountId=XXX --packageName=XXX --mode=overview
The program can run in two modes:
- to obtain an overview of various data about one or more of the apps on your Google Play developer account. The program outputs a csv file of summary data together with several screenshots of various reports per app you specify.
- to download error data for one or more of your apps on your Google Play developer account. for the Java packagenames specified in the
--packageName
command-line parameter.
--accountId
required--packageName
required (*
would download data for all the apps on the account)--days
(default7
)--mode
(defaulterrors
)--errorType
(defaultcrash,ANR
)--numExceptions=2
(defaultall
)--format
(default:csv
)--outDir
(default:./
)--parallel
(default:1
)--verbose
(default:false
)
npm run start:dev -- --accountId=<add-your-accountId> --mode=overview
If you use VSCode, there is a pre-configured launch config: .vscode/launch.json
. Note: this contains several examples of how to run the program so it may be worth reading even if you are not using VSCode.
This is preferable as no compilation step is required, and breakpoints can be used.
CLI typescript execution is provided by the start:dev
npm script in package.json
. When executing with these scripts, --
is required to tell bash to pass on the arguments.
E.g.
> npm run start:dev -- --accountId=XXX --packageName=XXX --format=json
There is a data playground.
If you have VSCode installed, there is a preset in .vscode/launch.json
which allows you to debug your data processing code.
Otherwise, you can call it form the command line like so:
> npm run playground -- --data=./android-crash-clusters_1557226424411.json
> npm install
> npm run build
> npm t
> npm run build && npm i -g .
A helpful article provides an overview and a worked example of using a similar approach that scrapes a booking website and generates JSON results. https://www.scrapehero.com/how-to-build-a-web-scraper-using-puppeteer-and-node-js/