home / opsnap

reports

Each row is one public submission to Operation Snap. Includes the offence, vehicle details, location, and outcome.

Disposal outcomes: Education (driver awareness course), Warning Letter, Fixed Penalty (fine), Court (prosecution), NFA (no further action).

Data license: ODbL · Data source: West Midlands Police

id
{'label': 'ID'}
source_file
{'label': 'Source PDF'}
source_page
{'label': 'Page'}
source_row
{'label': 'Row'}
month
{'label': 'Month'}
reporter_transport_mode
{'label': 'Reporter'}
vehicle_make
{'label': 'Make'}
vehicle_model
{'label': 'Model'}
vehicle_colour
{'label': 'Colour'}
offence
{'label': 'Offence'}
second_offence
{'label': 'Second offence'}
offence_location_raw
{'label': 'Location (raw)'}
offence_location
{'label': 'Location'}
council_area_raw
{'label': 'Council (raw)'}
council_area
{'label': 'Council area'}
disposal
{'label': 'Outcome'}
nfa_rationale
{'label': 'NFA reason'}
witness_contacted
{'label': 'Witness contacted'}
latitude
{'label': 'Lat'}
longitude
{'label': 'Lng'}

5 rows where council_area = "Out of Force Area", month = "2025-10" and vehicle_make = "Kia" sorted by month descending

✎ View and edit SQL

This data as json, CSV (advanced)

Suggested facets: vehicle_model, vehicle_colour

offence 4

  • Driving without Due Care and Attention 2
  • Cause unnecessary obstruction by motor vehicle / trailer outside of the Greater London area 1
  • Contravening a Red Traffic Light 1
  • Using a Mobile Phone Whilst Driving 1

reporter_transport_mode 3

  • Car 3
  • Pedal Bike 1
  • Pedestrian 1

vehicle_make 1

  • Kia · 5 ✖

month 1

  • 2025-10 · 5 ✖

disposal 1

  • NFA 5

council_area 1

  • Out of Force Area · 5 ✖
id source_file source_page source_row month ▲ reporter_transport_mode vehicle_make vehicle_model vehicle_colour offence second_offence offence_location_raw offence_location council_area_raw council_area disposal nfa_rationale witness_contacted latitude longitude
22078 op-snap---monthly-publication-october-2025.pdf   28 2025-10 Car Kia Sportage Black Contravening a Red Traffic Light None M42 J9 Island M42 J9 Island Out of Force Area Out of Force Area NFA Out of Force   52.3601724 -1.8062199
22230 op-snap---monthly-publication-october-2025.pdf   180 2025-10 Pedal Bike Kia Soul Blue Using a Mobile Phone Whilst Driving None Roman Way (Droitwich) Roman Way (Droitwich) Out of Force Area Out of Force Area NFA Out of Force      
22384 op-snap---monthly-publication-october-2025.pdf   334 2025-10 Car Kia Soul Black Driving without Due Care and Attention None A4440 Grove Way, Worcester Grove Way, Worcester Out of Force Area Out of Force Area NFA Out of Force      
23446 op-snap---monthly-publication-october-2025.pdf   1396 2025-10 Car Kia Sportage Grey Driving without Due Care and Attention None Hanley, Staffs Hanley, Staffs Out of Force Area Out of Force Area NFA Out of Force      
23565 op-snap---monthly-publication-october-2025.pdf   1515 2025-10 Pedestrian Kia   Silver Cause unnecessary obstruction by motor vehicle / trailer outside of the Greater London area None Worcester Road. OOF Worcester Road. OOF Out of Force Area Out of Force Area NFA Out of Force      

Advanced export

JSON shape: default, array, newline-delimited, object

CSV options:

CREATE TABLE reports (
            id INTEGER PRIMARY KEY AUTOINCREMENT,
            source_file TEXT NOT NULL,
            source_page INTEGER,
            source_row INTEGER,
            month TEXT NOT NULL,
            reporter_transport_mode TEXT,
            vehicle_make TEXT,
            vehicle_model TEXT,
            vehicle_colour TEXT,
            offence TEXT,
            second_offence TEXT,
            offence_location_raw TEXT,
            offence_location TEXT,
            council_area_raw TEXT,
            council_area TEXT,
            disposal TEXT,
            nfa_rationale TEXT,
            witness_contacted TEXT
        , latitude REAL, longitude REAL);
CREATE INDEX idx_month ON reports(month);
CREATE INDEX idx_council_area ON reports(council_area);
CREATE INDEX idx_offence ON reports(offence);
CREATE INDEX idx_disposal ON reports(disposal);
CREATE INDEX idx_location ON reports(offence_location);