-
Notifications
You must be signed in to change notification settings - Fork 24
/
Copy pathget_datasets.py
61 lines (47 loc) · 1.7 KB
/
get_datasets.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
'''
Gets a list of available datasets from the Oxford Robotcar Dataset website.
Matt Gadd
Mar 2019
Oxford Robotics Institute, Oxford University.
'''
import requests
import re
from scrape_mrgdatashare import datasets_url
def main():
# open session
session_requests = requests.session()
# get http response from website
result = session_requests.get(datasets_url)
text = result.text
# parse response text
text_locations = [text_location.end()
for text_location in re.finditer(datasets_url, text)]
datasets = [str(text[text_location:text_location + 19])
for text_location in text_locations]
# ignore metadata and sort unique datasets
datasets = datasets[2:]
datasets = sorted(list(set(datasets)))
# write output text file
datasets_file = "datasets.csv"
with open(datasets_file, "w") as file_handle:
# iterate datasets
for dataset in datasets:
# url to dataset page
dataset_url = datasets_url + dataset
result = session_requests.get(dataset_url)
text = result.text
# parse text for sensor type
start = [
text_location.end() for text_location in re.finditer(
"download/\?filename=datasets", text)]
sensor_types = []
for s in start:
ss = s
while text[ss + 40:ss + 44] != ".tar":
ss += 1
sensor_type = text[s + 41:ss + 40]
sensor_types.append(str(sensor_type))
# write dataset entry
file_handle.write(dataset + "," + ",".join(sensor_types) + "\n")
if __name__ == "__main__":
main()