Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/n0madic/google-play-scraper
Golang scraper to get data from Google Play Store
https://github.com/n0madic/google-play-scraper
Last synced: about 2 months ago
JSON representation
Golang scraper to get data from Google Play Store
- Host: GitHub
- URL: https://github.com/n0madic/google-play-scraper
- Owner: n0madic
- License: lgpl-3.0
- Created: 2019-09-20T14:03:01.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2023-10-14T12:28:08.000Z (over 1 year ago)
- Last Synced: 2024-07-31T20:53:20.155Z (6 months ago)
- Language: Go
- Homepage:
- Size: 83 KB
- Stars: 79
- Watchers: 5
- Forks: 20
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-go - google-play-scraper - Get data from Google Play Store. (Third-party APIs / Utility/Miscellaneous)
- awesome-go-extra - google-play-scraper - 09-20T14:03:01Z|2022-08-23T09:48:37Z| (Third-party APIs / Fail injection)
README
# google-play-scraper
[![GoDoc](https://godoc.org/github.com/n0madic/google-play-scraper/pkg?status.svg)](https://godoc.org/github.com/n0madic/google-play-scraper/pkg)
[![Go Report Card](https://goreportcard.com/badge/github.com/n0madic/google-play-scraper)](https://goreportcard.com/report/github.com/n0madic/google-play-scraper)
[![Coverage Status](https://coveralls.io/repos/github/n0madic/google-play-scraper/badge.svg?branch=master)](https://coveralls.io/github/n0madic/google-play-scraper?branch=master)Golang scraper to get data from Google Play Store
This project is inspired by the [google-play-scraper](https://github.com/facundoolano/google-play-scraper) node.js project
## Installation
```shell
go get -u github.com/n0madic/google-play-scraper/...
```## Usage
### Get app details
Retrieves the full detail of an application.
```go
package mainimport (
"github.com/davecgh/go-spew/spew"
"github.com/n0madic/google-play-scraper/pkg/app"
)func main() {
a := app.New("com.google.android.googlequicksearchbox", app.Options{
Country: "us",
Language: "us",
})
err := a.LoadDetails()
if err != nil {
panic(err)
}
err = a.LoadPermissions()
if err != nil {
panic(err)
}
spew.Dump(a)
}
```### Search apps
Retrieves a list of apps that results of searching by the given term.
```go
package mainimport (
"fmt""github.com/n0madic/google-play-scraper/pkg/search"
)func main() {
query := search.NewQuery("game", search.PricePaid,
search.Options{
Country: "ru",
Language: "us",
Number: 100,
Discount: true,
PriceMax: 100,
ScoreMin: 4,
})err := query.Run()
if err != nil {
panic(err)
}errors := query.LoadMoreDetails(20)
if len(errors) > 0 {
panic(errors[0])
}for _, app := range query.Results {
if !app.IAPOffers {
fmt.Println(app.Title, app.URL)
}
}
}
```### Get category
Returns a list of clusters for the specified application category.
```go
package mainimport (
"fmt""github.com/n0madic/google-play-scraper/pkg/category"
"github.com/n0madic/google-play-scraper/pkg/store"
)func main() {
clusters, err := category.New(store.Game, store.AgeFiveUnder, category.Options{
Country: "us",
Language: "us",
Number: 100,
})
if err != nil {
panic(err)
}clusterName := "New & updated games"
err = clusters[clusterName].Run()
if err != nil {
panic(err)
}for _, app := range clusters[clusterName].Results {
fmt.Println(app.Title, app.URL)
}
}
```### Get collection
Retrieve a list of applications from one of the collections at Google Play.
```go
package mainimport (
"fmt""github.com/n0madic/google-play-scraper/pkg/collection"
"github.com/n0madic/google-play-scraper/pkg/store"
)func main() {
c := collection.New(store.TopNewPaid, collection.Options{
Country: "uk",
Number: 100,
})
err := c.Run()
if err != nil {
panic(err)
}for _, app := range c.Results {
fmt.Println(app.Title, app.Price, app.URL)
}
}
```### Get developer applications
Returns the list of applications by the given developer name or ID
```go
package mainimport (
"fmt""github.com/n0madic/google-play-scraper/pkg/developer"
)func main() {
dev := developer.New("Google LLC", developer.Options{
Number: 100,
})
err := dev.Run()
if err != nil {
panic(err)
}for _, app := range dev.Results {
fmt.Println(app.Title, "by", app.Developer, app.URL)
}
}
```### Get reviews
Retrieves a page of reviews for a specific application.
Note that this method returns reviews in a specific language (english by default), so you need to try different languages to get more reviews. Also, the counter displayed in the Google Play page refers to the total number of 1-5 stars ratings the application has, not the written reviews count. So if the app has 100k ratings, don't expect to get 100k reviews by using this method.
```go
package mainimport (
"fmt""github.com/n0madic/google-play-scraper/pkg/reviews"
)func main() {
r := reviews.New("com.activision.callofduty.shooter", reviews.Options{
Number: 100,
})err := r.Run()
if err != nil {
panic(err)
}for _, review := range r.Results {
fmt.Println(review.Score, review.Text)
}
}
```### Get similar
Returns a list of similar apps to the one specified.
```go
package mainimport (
"fmt""github.com/n0madic/google-play-scraper/pkg/similar"
)func main() {
sim := similar.New("com.android.chrome", similar.Options{
Number: 100,
})
err := sim.Run()
if err != nil {
panic(err)
}for _, app := range sim.Results {
fmt.Println(app.Title, app.URL)
}
}
```### Get suggest
Given a string returns up to five suggestion to complete a search query term.
```go
package mainimport (
"fmt""github.com/n0madic/google-play-scraper/pkg/suggest"
)func main() {
sug, err := suggest.Get("chrome", suggest.Options{
Country: "us",
Language: "us",
})
if err != nil {
panic(err)
}for _, s := range sug {
fmt.Println(s)
}
}
```