File: performance.py

package info (click to toggle)
csvkit 2.2.0-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 40,664 kB
  • sloc: python: 4,924; perl: 1,000; makefile: 131; sql: 4
file content (67 lines) | stat: -rw-r--r-- 2,764 bytes parent folder | download | duplicates (2)
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
62
63
64
65
66
67
import os.path
import subprocess
import timeit

num_repeats = 100  # number of repeats for timeit


def test_csvformat_performance():
    command = ['csvformat', os.path.join('examples', 'iris.csv')]
    start_time = timeit.default_timer()
    for _ in range(num_repeats):
        subprocess.run(command, stdout=subprocess.DEVNULL)  # redirect output to DEVNULL as we don't want to print it
    elapsed = timeit.default_timer() - start_time
    print(f"CSVKit csvformat performance test elapsed time: {elapsed} seconds")


def test_csvjson_performance():
    command = ['csvjson', os.path.join('examples', 'iris.csv')]
    start_time = timeit.default_timer()
    for _ in range(num_repeats):
        subprocess.run(command, stdout=subprocess.DEVNULL)  # redirect output to DEVNULL as we don't want to print it
    elapsed = timeit.default_timer() - start_time
    print(f"CSVKit csvjson performance test elapsed time: {elapsed} seconds")


def test_csvlook_performance():
    command = ['csvlook', os.path.join('examples', 'iris.csv')]
    start_time = timeit.default_timer()
    for _ in range(num_repeats):
        subprocess.run(command, stdout=subprocess.DEVNULL)  # redirect output to DEVNULL as we don't want to print it
    elapsed = timeit.default_timer() - start_time
    print(f"CSVKit csvlook performance test elapsed time: {elapsed} seconds")


def test_csvpy_performance():
    command = ['csvpy', os.path.join('examples', 'iris.csv')]
    start_time = timeit.default_timer()
    for _ in range(num_repeats):
        subprocess.run(command, stdout=subprocess.DEVNULL)  # redirect output to DEVNULL as we don't want to print it
    elapsed = timeit.default_timer() - start_time
    print(f"CSVKit csvpy performance test elapsed time: {elapsed} seconds")


def test_csvsql_performance():
    command = ['csvsql', os.path.join('examples', 'iris.csv')]
    start_time = timeit.default_timer()
    for _ in range(num_repeats):
        subprocess.run(command, stdout=subprocess.DEVNULL)  # redirect output to DEVNULL as we don't want to print it
    elapsed = timeit.default_timer() - start_time
    print(f"CSVKit csvsql performance test elapsed time: {elapsed} seconds")


def test_csvstat_performance():
    command = ['csvstat', os.path.join('examples', 'iris.csv')]
    start_time = timeit.default_timer()
    for _ in range(num_repeats):
        subprocess.run(command, stdout=subprocess.DEVNULL)  # redirect output to DEVNULL as we don't want to print it
    elapsed = timeit.default_timer() - start_time
    print(f"CSVKit csvstat performance test elapsed time: {elapsed} seconds")


test_csvformat_performance()
test_csvjson_performance()
test_csvlook_performance()
# test_csvpy_performance()
# test_csvsql_performance()
test_csvstat_performance()