-
-
Notifications
You must be signed in to change notification settings - Fork 13
Stats
Raphaël Odini edited this page Jan 2, 2025
·
20 revisions
- 30k (2024-7-29)
- 40k (2024-10-24)
- 50k (2024-11-24)
- 60k (2024-12-30)
// Counter(Price.objects.values_list("source", flat=True))
// 2024-12-23
None: 27528,
'Open Prices Web App': 11701,
'API': 9946,
'Open Prices Web App (/prices/add/multiple)': 4084,
'Smoothie - OpenFoodFacts': 1979,
'Open Prices Web App (/experiments/contribution-assistant)': 1252,
'Smoothie - OpenFoodFacts (4.16.1+1364)': 871,
'Open Prices Web App (/experiments/price-validator-assistant)': 331,
'Smoothie - OpenFoodFacts (4.16.9+1402)': 277,
'Smoothie - OpenFoodFacts (0.0.0+734)': 127,
'Smoothie - OpenFoodFacts (4.16.0+1357)': 76,
'Smoothie - OpenFoodFacts (4.16.0+1348)': 72,
'Smoothie - OpenFoodFacts (4.17.0+1403)': 70,
'Open Prices Web App (/prices/add/single)': 35,
'Smoothie - OpenFoodFacts (4.16.0+1346)': 35,
'Smoothie - OpenFoodFacts (4.15.0+1345)': 21,
'Smoothie - OpenFoodFacts (4.17.0+1402)': 21,
'Smoothie - OpenFoodFacts (4.15.0+1331)': 18,
'Smoothie - OpenFoodFacts (4.16.9+1383)': 14,
'Smoothie - OpenFoodFacts (4.16.9+1390)': 12,
'Smoothie - OpenFoodFacts (4.16.9+1377)': 11,
'Open Prices Web App (/prices)': 6,
'Smoothie - OpenFoodFacts (4.17.0+1404)': 5,
'Smoothie - OpenFoodFacts (4.16.9+1368)': 4,
'Smoothie - OpenFoodFacts (4.17.1+1405)': 4,
'Smoothie - OpenFoodFacts (4.17.1+1406)': 3,
'Smoothie - OpenFoodFacts (4.15.1+1334)': 2,
'Smoothie - OpenFoodFacts (4.16.9+1371)': 2,
'Smoothie - OpenFoodFacts (4.16.9+1400)': 1,
'MyMeals': 1,
'Smoothie - OpenFoodFacts (4.16.9+1391)': 1,
'Smoothie - OpenFoodFacts (4.14.0+1330)': 1,
'Smoothie - OpenFoodFacts (4.17.1+1408)': 1
unique_scans_n
Date | Flavor | Top 100 | Top 1000 |
---|---|---|---|
2024-08-24 | OFF | 80 | 567 |
2024-09-13 | OFF | 81 | 583 |
LIMIT = 100
queryset = Product.objects.filter(source="off").order_by("-unique_scans_n")[:LIMIT].values_list("price_count", flat=True)
len(list(filter(lambda pc: pc != 0, list(queryset))))
Date | OFF | OPF | OBF | OPFF | unknown |
---|---|---|---|---|---|
2024-09-13 | 16046 / 3390281 | 201 / 15618 | 157 / 30634 | 33 / 9713 | 2476 / 4441 |
2024-12-04 | 24679 / 3624143 | 252 / 15741 | 222 / 31463 | 75 / 9955 | 4038 / 5484 |
from open_prices.products import constants as product_constants
for flavor in product_constants.SOURCE_LIST + [None]:
print(flavor, Product.objects.filter(source=flavor).filter(price_count__gte=1).count(), "/", Product.objects.filter(source=flavor).count())
// Counter(Proof.objects.values_list("source", flat=True))
// 2024-12-23
None: 7363,
'Open Prices Web App': 2341,
'Smoothie - OpenFoodFacts': 1238,
'API': 938,
'Smoothie - OpenFoodFacts (4.16.1+1364)': 758,
'Open Prices Web App (/proofs/add/multiple)': 650,
'Open Prices Web App (/prices/add/multiple)': 634,
'Smoothie - OpenFoodFacts (4.16.9+1402)': 193,
'Open Prices Web App (/experiments/contribution-assistant)': 113,
'Smoothie - OpenFoodFacts (4.16.0+1357)': 74,
'Smoothie - OpenFoodFacts (4.16.0+1346)': 69,
'Smoothie - OpenFoodFacts (4.16.0+1348)': 68,
'Smoothie - OpenFoodFacts (4.17.0+1403)': 48,
'Smoothie - OpenFoodFacts (0.0.0+734)': 33,
'Open Prices Web App (/prices/add/single)': 23,
'Smoothie - OpenFoodFacts (4.15.0+1345)': 21,
'Smoothie - OpenFoodFacts (4.17.0+1402)': 17,
'Smoothie - OpenFoodFacts (4.15.0+1331)': 10,
'Open Prices Web App (/dashboard)': 8,
'Smoothie - OpenFoodFacts (4.16.9+1390)': 7,
'Smoothie - OpenFoodFacts (4.16.9+1383)': 6,
'Smoothie - OpenFoodFacts (4.17.1+1405)': 4,
'Smoothie - OpenFoodFacts (4.16.9+1377)': 3,
'Open Prices Web App (/experiments/price-validator-assistant)': 3,
'Smoothie - OpenFoodFacts (4.15.1+1334)': 2,
'Smoothie - OpenFoodFacts (4.16.9+1368)': 2,
'Smoothie - OpenFoodFacts (4.17.0+1404)': 2,
'Open Prices Web App (/experiments)': 2,
'Smoothie - OpenFoodFacts (4.16.9+1371)': 1,
'Smoothie - OpenFoodFacts (4.16.9+1391)': 1,
'Smoothie - OpenFoodFacts (4.16.9+1400)': 1,
'Smoothie - OpenFoodFacts (4.14.0+1330)': 1,
'Open Prices Web App (/proofs/add/single)': 1,
'Smoothie - OpenFoodFacts (4.17.1+1408)': 1
// price tag count
PriceTag.objects.filter(proof__ready_for_price_tag_validation=True, status=None).count()
// proof involved count
PriceTag.objects.filter(proof__ready_for_price_tag_validation=True, status=None).values_list("proof_id", flat=True).distinct().count()
from collections import Counter
// proof owners
proof_id_list = PriceTag.objects.filter(proof__ready_for_price_tag_validation=True, status=None).values_list("proof_id", flat=True).distinct()
Counter(Proof.objects.filter(id__in=proof_id_list).values_list("owner", flat=True))
// price tag "owners"
Counter(PriceTag.objects.filter(proof__ready_for_price_tag_validation=True, status=None).values_list("proof__owner", flat=True))
from collections import Counter
queryset = Price.objects.values_list("location__osm_address_country", flat=True)
Counter(queryset)
from collections import Counter
from django.db.models import F, Value, CharField
from django.db.models.functions import Concat
queryset = Location.objects.annotate(city_country=Concat(F("location__osm_address_city"), Value(":"), F("location__osm_address_country"), output_field=CharField())).values_list("city_country", flat=True)
Counter(queryset)
// top 30, stats from 18/09/2024 (550 results)
'Grenoble, France': 6661,
'Belley, France': 5273,
'Bergen, Norge': 4115,
'Miribel, France': 2752,
'Paris, France': 1123,
'Échirolles, France': 1036,
'Canteleu, France': 858,
'Noyelles-Godault, France': 777,
'Marcq-en-Barœul, France': 687,
'Berlin, Deutschland': 483,
'Veynes, France': 452,
'Nantes, France': 408,
'Münster, Deutschland': 341,
'Levallois-Perret, France': 339,
'Le Kremlin-Bicêtre, France': 304,
'Vincennes, France': 288,
'Lille, France': 285,
'Gap, France': 263,
'Lyon, France': 246,
'Bezons, France': 243,
'Bresson, France': 211,
'Strausberg, Deutschland': 181,
'Avignon, France': 168,
'Mons-en-Barœul, France': 164,
'Aulnay-sous-Bois, France': 148,
'Sant Feliu de Llobregat, España': 143,
'Huningue, France': 131,
'Villeurbanne, France': 125,
'Donzère, France': 115,
'Ouistreham, France': 115
(...)
from collections import Counter
from django.db.models import F, Value, CharField
from django.db.models.functions import Concat
queryset = Location.objects.annotate(osm_tag=Concat(F("osm_tag_key"), Value(":"), F("osm_tag_value"), output_field=CharField())).values_list("osm_tag", flat=True)
Counter(queryset)
// top 30, stats from 08/09/2024 (961 locations)
'shop:supermarket': 614,
'shop:convenience': 76,
'boundary:administrative': 25,
'amenity:fuel': 18,
'shop:chemist': 13,
'shop:variety_store': 13,
'place:house': 7,
'highway:bus_stop': 7,
'shop:bakery': 7,
'shop:mall': 7,
'shop:deli': 7,
'shop:frozen_food': 6,
'landuse:retail': 6,
'amenity:pharmacy': 6,
'railway:station': 6,
'landuse:construction': 5,
'shop:greengrocer': 5,
'shop:furniture': 5,
'landuse:industrial': 4,
'shop:department_store': 4,
'shop:farm': 4,
'building:yes': 4,
'shop:wholesale': 4,
'shop:books': 3,
'amenity:fast_food': 3,
'shop:sports': 3,
'place:city': 3,
'shop:doityourself': 3,
'amenity:cafe': 3,
'place:suburb': 3
(...)
from collections import Counter
queryset = Price.objects.values_list("location__osm_name", flat=True)
Counter(queryset)
// top 30, stats from 18/09/2024 (490 results)
'Auchan': 6220,
'Carrefour Market': 3455,
'Auchan Supermarché': 2889,
'Intermarché': 1850,
'Extra Danmarksplass': 1572,
'Super U': 1186,
'Monoprix': 1153,
"L'Éléfàn": 1137,
'E.Leclerc': 953,
'E. Leclerc': 742,
'Lidl': 686,
'Carrefour': 507,
'Carrefour City': 477,
'Kiwi Bøhmergaten': 443,
'U Express': 428,
'Netto': 391,
'Bunnpris Damsgård': 383,
'Rema 1000 Marken': 317,
'Circle K Viken': 299,
'Aldi': 267,
'Naturalia': 242,
"Bio C' Bon": 234,
'Biocoop': 224,
'Picard': 222,
'Rema 1000 Danmarksplass': 220,
'Intermarché Super Bresson': 211,
'Gigaboks Åsane': 208,
"L'Eau Vive": 200,
'Satoriz Échirolles': 187,
'Europris Xhibition': 175
(...)