meerschaum 2.6.14__py3-none-any.whl → 2.6.16__py3-none-any.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,517 +0,0 @@
1
- Metadata-Version: 2.1
2
- Name: meerschaum
3
- Version: 2.6.14
4
- Summary: Sync Time-Series Pipes with Meerschaum
5
- Home-page: https://meerschaum.io
6
- Author: Bennett Meares
7
- Author-email: bennett.meares@gmail.com
8
- Maintainer-email: bennett.meares@gmail.com
9
- License: Apache Software License 2.0
10
- Project-URL: Documentation, https://docs.meerschaum.io
11
- Project-URL: Changelog, https://meerschaum.io/news/changelog
12
- Project-URL: GitHub, https://github.com/bmeares/Meerschaum
13
- Project-URL: Homepage, https://meerschaum.io
14
- Project-URL: Donate, https://github.com/sponsors/bmeares
15
- Project-URL: Discord, https://discord.gg/8U8qMUjvcc
16
- Classifier: Development Status :: 5 - Production/Stable
17
- Classifier: Intended Audience :: System Administrators
18
- Classifier: License :: OSI Approved :: Apache Software License
19
- Classifier: Operating System :: POSIX :: Linux
20
- Classifier: Operating System :: Microsoft :: Windows
21
- Classifier: Operating System :: MacOS
22
- Classifier: Programming Language :: SQL
23
- Classifier: Programming Language :: Python :: 3.9
24
- Classifier: Programming Language :: Python :: 3.10
25
- Classifier: Programming Language :: Python :: 3.11
26
- Classifier: Programming Language :: Python :: 3.12
27
- Classifier: Programming Language :: Python :: 3.13
28
- Classifier: Topic :: Database
29
- Classifier: Natural Language :: English
30
- Requires-Python: >=3.8
31
- Description-Content-Type: text/markdown
32
- License-File: LICENSE
33
- License-File: NOTICE
34
- Provides-Extra: api
35
- Requires-Dist: uvicorn[standard] >=0.29.0 ; extra == 'api'
36
- Requires-Dist: gunicorn >=22.0.0 ; extra == 'api'
37
- Requires-Dist: python-dotenv >=0.20.0 ; extra == 'api'
38
- Requires-Dist: websockets >=11.0.3 ; extra == 'api'
39
- Requires-Dist: fastapi >=0.111.0 ; extra == 'api'
40
- Requires-Dist: fastapi-login >=1.7.2 ; extra == 'api'
41
- Requires-Dist: python-multipart >=0.0.9 ; extra == 'api'
42
- Requires-Dist: httpx >=0.27.2 ; extra == 'api'
43
- Requires-Dist: httpcore >=1.0.6 ; extra == 'api'
44
- Requires-Dist: valkey >=6.0.0 ; extra == 'api'
45
- Requires-Dist: numpy >=1.18.5 ; extra == 'api'
46
- Requires-Dist: pandas[parquet] >=2.0.1 ; extra == 'api'
47
- Requires-Dist: pyarrow >=16.1.0 ; extra == 'api'
48
- Requires-Dist: dask[complete] >=2024.5.1 ; extra == 'api'
49
- Requires-Dist: partd >=1.4.2 ; extra == 'api'
50
- Requires-Dist: pytz ; extra == 'api'
51
- Requires-Dist: joblib >=0.17.0 ; extra == 'api'
52
- Requires-Dist: SQLAlchemy >=2.0.5 ; extra == 'api'
53
- Requires-Dist: databases >=0.4.0 ; extra == 'api'
54
- Requires-Dist: aiosqlite >=0.16.0 ; extra == 'api'
55
- Requires-Dist: asyncpg >=0.21.0 ; extra == 'api'
56
- Requires-Dist: cryptography >=38.0.1 ; extra == 'api'
57
- Requires-Dist: psycopg[binary] >=3.2.1 ; extra == 'api'
58
- Requires-Dist: PyMySQL >=0.9.0 ; extra == 'api'
59
- Requires-Dist: aiomysql >=0.0.21 ; extra == 'api'
60
- Requires-Dist: sqlalchemy-cockroachdb >=2.0.0 ; extra == 'api'
61
- Requires-Dist: duckdb >=1.0.0 ; extra == 'api'
62
- Requires-Dist: duckdb-engine >=0.13.0 ; extra == 'api'
63
- Requires-Dist: wheel >=0.34.2 ; extra == 'api'
64
- Requires-Dist: setuptools >=63.3.0 ; extra == 'api'
65
- Requires-Dist: PyYAML >=5.3.1 ; extra == 'api'
66
- Requires-Dist: pip >=22.0.4 ; extra == 'api'
67
- Requires-Dist: update-checker >=0.18.0 ; extra == 'api'
68
- Requires-Dist: semver >=3.0.2 ; extra == 'api'
69
- Requires-Dist: pathspec >=0.9.0 ; extra == 'api'
70
- Requires-Dist: python-dateutil >=2.7.5 ; extra == 'api'
71
- Requires-Dist: requests >=2.32.3 ; extra == 'api'
72
- Requires-Dist: certifi >=2024.8.30 ; extra == 'api'
73
- Requires-Dist: idna >=3.10.0 ; extra == 'api'
74
- Requires-Dist: binaryornot >=0.4.4 ; extra == 'api'
75
- Requires-Dist: pyvim >=3.0.2 ; extra == 'api'
76
- Requires-Dist: ptpython >=3.0.27 ; extra == 'api'
77
- Requires-Dist: aiofiles >=0.6.0 ; extra == 'api'
78
- Requires-Dist: packaging >=21.3.0 ; extra == 'api'
79
- Requires-Dist: prompt-toolkit >=3.0.39 ; extra == 'api'
80
- Requires-Dist: more-itertools >=8.7.0 ; extra == 'api'
81
- Requires-Dist: fasteners >=0.19.0 ; extra == 'api'
82
- Requires-Dist: virtualenv >=20.1.0 ; extra == 'api'
83
- Requires-Dist: attrs >=24.2.0 ; extra == 'api'
84
- Requires-Dist: uv >=0.2.11 ; extra == 'api'
85
- Requires-Dist: pprintpp >=0.4.0 ; extra == 'api'
86
- Requires-Dist: asciitree >=0.3.3 ; extra == 'api'
87
- Requires-Dist: typing-extensions >=4.7.1 ; extra == 'api'
88
- Requires-Dist: pygments >=2.7.2 ; extra == 'api'
89
- Requires-Dist: colorama >=0.4.3 ; extra == 'api'
90
- Requires-Dist: rich >=13.4.2 ; extra == 'api'
91
- Requires-Dist: more-termcolor >=1.1.3 ; extra == 'api'
92
- Requires-Dist: humanfriendly >=10.0.0 ; extra == 'api'
93
- Requires-Dist: Flask-Compress >=1.10.1 ; extra == 'api'
94
- Requires-Dist: dash >=2.6.2 ; extra == 'api'
95
- Requires-Dist: dash-bootstrap-components >=1.2.1 ; extra == 'api'
96
- Requires-Dist: dash-ace >=0.2.1 ; extra == 'api'
97
- Requires-Dist: dash-extensions >=1.0.4 ; extra == 'api'
98
- Requires-Dist: dash-daq >=0.5.0 ; extra == 'api'
99
- Requires-Dist: terminado >=0.12.1 ; extra == 'api'
100
- Requires-Dist: tornado >=6.1.0 ; extra == 'api'
101
- Requires-Dist: dill >=0.3.3 ; extra == 'api'
102
- Requires-Dist: python-daemon >=0.2.3 ; extra == 'api'
103
- Requires-Dist: watchfiles >=0.21.0 ; extra == 'api'
104
- Requires-Dist: psutil >=5.8.0 ; extra == 'api'
105
- Provides-Extra: build
106
- Requires-Dist: cx-Freeze >=7.0.0 ; extra == 'build'
107
- Requires-Dist: pyinstaller >6.6.0 ; extra == 'build'
108
- Provides-Extra: cli
109
- Requires-Dist: pgcli >=3.1.0 ; extra == 'cli'
110
- Requires-Dist: mycli >=1.23.2 ; extra == 'cli'
111
- Requires-Dist: litecli >=1.5.0 ; extra == 'cli'
112
- Requires-Dist: mssql-cli >=1.0.0 ; extra == 'cli'
113
- Requires-Dist: gadwall >=0.2.0 ; extra == 'cli'
114
- Provides-Extra: core
115
- Requires-Dist: wheel >=0.34.2 ; extra == 'core'
116
- Requires-Dist: setuptools >=63.3.0 ; extra == 'core'
117
- Requires-Dist: PyYAML >=5.3.1 ; extra == 'core'
118
- Requires-Dist: pip >=22.0.4 ; extra == 'core'
119
- Requires-Dist: update-checker >=0.18.0 ; extra == 'core'
120
- Requires-Dist: semver >=3.0.2 ; extra == 'core'
121
- Requires-Dist: pathspec >=0.9.0 ; extra == 'core'
122
- Requires-Dist: python-dateutil >=2.7.5 ; extra == 'core'
123
- Requires-Dist: requests >=2.32.3 ; extra == 'core'
124
- Requires-Dist: certifi >=2024.8.30 ; extra == 'core'
125
- Requires-Dist: idna >=3.10.0 ; extra == 'core'
126
- Requires-Dist: binaryornot >=0.4.4 ; extra == 'core'
127
- Requires-Dist: pyvim >=3.0.2 ; extra == 'core'
128
- Requires-Dist: ptpython >=3.0.27 ; extra == 'core'
129
- Requires-Dist: aiofiles >=0.6.0 ; extra == 'core'
130
- Requires-Dist: packaging >=21.3.0 ; extra == 'core'
131
- Requires-Dist: prompt-toolkit >=3.0.39 ; extra == 'core'
132
- Requires-Dist: more-itertools >=8.7.0 ; extra == 'core'
133
- Requires-Dist: fasteners >=0.19.0 ; extra == 'core'
134
- Requires-Dist: virtualenv >=20.1.0 ; extra == 'core'
135
- Requires-Dist: attrs >=24.2.0 ; extra == 'core'
136
- Requires-Dist: uv >=0.2.11 ; extra == 'core'
137
- Provides-Extra: dash
138
- Requires-Dist: Flask-Compress >=1.10.1 ; extra == 'dash'
139
- Requires-Dist: dash >=2.6.2 ; extra == 'dash'
140
- Requires-Dist: dash-bootstrap-components >=1.2.1 ; extra == 'dash'
141
- Requires-Dist: dash-ace >=0.2.1 ; extra == 'dash'
142
- Requires-Dist: dash-extensions >=1.0.4 ; extra == 'dash'
143
- Requires-Dist: dash-daq >=0.5.0 ; extra == 'dash'
144
- Requires-Dist: terminado >=0.12.1 ; extra == 'dash'
145
- Requires-Dist: tornado >=6.1.0 ; extra == 'dash'
146
- Provides-Extra: dev-tools
147
- Requires-Dist: twine >=3.2.0 ; extra == 'dev-tools'
148
- Requires-Dist: tuna >=0.5.3 ; extra == 'dev-tools'
149
- Requires-Dist: snakeviz >=2.1.0 ; extra == 'dev-tools'
150
- Requires-Dist: mypy >=0.812.0 ; extra == 'dev-tools'
151
- Requires-Dist: pytest >=6.2.2 ; extra == 'dev-tools'
152
- Requires-Dist: pytest-xdist >=3.2.1 ; extra == 'dev-tools'
153
- Requires-Dist: heartrate >=0.2.1 ; extra == 'dev-tools'
154
- Requires-Dist: build >=1.2.1 ; extra == 'dev-tools'
155
- Requires-Dist: attrs >=24.2.0 ; extra == 'dev-tools'
156
- Provides-Extra: docs
157
- Requires-Dist: mkdocs >=1.1.2 ; extra == 'docs'
158
- Requires-Dist: mkdocs-material >=6.2.5 ; extra == 'docs'
159
- Requires-Dist: mkdocs-material-extensions >=1.0.3 ; extra == 'docs'
160
- Requires-Dist: mkdocs-autolinks-plugin >=0.2.0 ; extra == 'docs'
161
- Requires-Dist: mkdocs-awesome-pages-plugin >=2.5.0 ; extra == 'docs'
162
- Requires-Dist: mkdocs-section-index >=0.3.3 ; extra == 'docs'
163
- Requires-Dist: mkdocs-linkcheck >=1.0.6 ; extra == 'docs'
164
- Requires-Dist: mkdocs-redirects >=1.0.4 ; extra == 'docs'
165
- Requires-Dist: jinja2 ==3.0.3 ; extra == 'docs'
166
- Provides-Extra: drivers
167
- Requires-Dist: cryptography >=38.0.1 ; extra == 'drivers'
168
- Requires-Dist: psycopg[binary] >=3.2.1 ; extra == 'drivers'
169
- Requires-Dist: PyMySQL >=0.9.0 ; extra == 'drivers'
170
- Requires-Dist: aiomysql >=0.0.21 ; extra == 'drivers'
171
- Requires-Dist: sqlalchemy-cockroachdb >=2.0.0 ; extra == 'drivers'
172
- Requires-Dist: duckdb >=1.0.0 ; extra == 'drivers'
173
- Requires-Dist: duckdb-engine >=0.13.0 ; extra == 'drivers'
174
- Provides-Extra: drivers-extras
175
- Requires-Dist: pyodbc >=4.0.30 ; extra == 'drivers-extras'
176
- Requires-Dist: cx-Oracle >=8.3.0 ; extra == 'drivers-extras'
177
- Provides-Extra: extras
178
- Requires-Dist: cmd2 >=1.4.0 ; extra == 'extras'
179
- Requires-Dist: ruamel.yaml >=0.16.12 ; extra == 'extras'
180
- Requires-Dist: modin[ray] >=0.8.3 ; extra == 'extras'
181
- Requires-Dist: nanoid >=2.0.0 ; extra == 'extras'
182
- Requires-Dist: importlib-metadata >=4.12.0 ; extra == 'extras'
183
- Provides-Extra: formatting
184
- Requires-Dist: pprintpp >=0.4.0 ; extra == 'formatting'
185
- Requires-Dist: asciitree >=0.3.3 ; extra == 'formatting'
186
- Requires-Dist: typing-extensions >=4.7.1 ; extra == 'formatting'
187
- Requires-Dist: pygments >=2.7.2 ; extra == 'formatting'
188
- Requires-Dist: colorama >=0.4.3 ; extra == 'formatting'
189
- Requires-Dist: rich >=13.4.2 ; extra == 'formatting'
190
- Requires-Dist: more-termcolor >=1.1.3 ; extra == 'formatting'
191
- Requires-Dist: humanfriendly >=10.0.0 ; extra == 'formatting'
192
- Provides-Extra: full
193
- Requires-Dist: pprintpp >=0.4.0 ; extra == 'full'
194
- Requires-Dist: asciitree >=0.3.3 ; extra == 'full'
195
- Requires-Dist: typing-extensions >=4.7.1 ; extra == 'full'
196
- Requires-Dist: pygments >=2.7.2 ; extra == 'full'
197
- Requires-Dist: colorama >=0.4.3 ; extra == 'full'
198
- Requires-Dist: rich >=13.4.2 ; extra == 'full'
199
- Requires-Dist: more-termcolor >=1.1.3 ; extra == 'full'
200
- Requires-Dist: humanfriendly >=10.0.0 ; extra == 'full'
201
- Requires-Dist: wheel >=0.34.2 ; extra == 'full'
202
- Requires-Dist: setuptools >=63.3.0 ; extra == 'full'
203
- Requires-Dist: PyYAML >=5.3.1 ; extra == 'full'
204
- Requires-Dist: pip >=22.0.4 ; extra == 'full'
205
- Requires-Dist: update-checker >=0.18.0 ; extra == 'full'
206
- Requires-Dist: semver >=3.0.2 ; extra == 'full'
207
- Requires-Dist: pathspec >=0.9.0 ; extra == 'full'
208
- Requires-Dist: python-dateutil >=2.7.5 ; extra == 'full'
209
- Requires-Dist: requests >=2.32.3 ; extra == 'full'
210
- Requires-Dist: certifi >=2024.8.30 ; extra == 'full'
211
- Requires-Dist: idna >=3.10.0 ; extra == 'full'
212
- Requires-Dist: binaryornot >=0.4.4 ; extra == 'full'
213
- Requires-Dist: pyvim >=3.0.2 ; extra == 'full'
214
- Requires-Dist: ptpython >=3.0.27 ; extra == 'full'
215
- Requires-Dist: aiofiles >=0.6.0 ; extra == 'full'
216
- Requires-Dist: packaging >=21.3.0 ; extra == 'full'
217
- Requires-Dist: prompt-toolkit >=3.0.39 ; extra == 'full'
218
- Requires-Dist: more-itertools >=8.7.0 ; extra == 'full'
219
- Requires-Dist: fasteners >=0.19.0 ; extra == 'full'
220
- Requires-Dist: virtualenv >=20.1.0 ; extra == 'full'
221
- Requires-Dist: attrs >=24.2.0 ; extra == 'full'
222
- Requires-Dist: uv >=0.2.11 ; extra == 'full'
223
- Requires-Dist: dill >=0.3.3 ; extra == 'full'
224
- Requires-Dist: python-daemon >=0.2.3 ; extra == 'full'
225
- Requires-Dist: watchfiles >=0.21.0 ; extra == 'full'
226
- Requires-Dist: psutil >=5.8.0 ; extra == 'full'
227
- Requires-Dist: cryptography >=38.0.1 ; extra == 'full'
228
- Requires-Dist: psycopg[binary] >=3.2.1 ; extra == 'full'
229
- Requires-Dist: PyMySQL >=0.9.0 ; extra == 'full'
230
- Requires-Dist: aiomysql >=0.0.21 ; extra == 'full'
231
- Requires-Dist: sqlalchemy-cockroachdb >=2.0.0 ; extra == 'full'
232
- Requires-Dist: duckdb >=1.0.0 ; extra == 'full'
233
- Requires-Dist: duckdb-engine >=0.13.0 ; extra == 'full'
234
- Requires-Dist: toga >=0.3.0-dev29 ; extra == 'full'
235
- Requires-Dist: pywebview >=3.6.3 ; extra == 'full'
236
- Requires-Dist: pycparser >=2.21.0 ; extra == 'full'
237
- Requires-Dist: numpy >=1.18.5 ; extra == 'full'
238
- Requires-Dist: pandas[parquet] >=2.0.1 ; extra == 'full'
239
- Requires-Dist: pyarrow >=16.1.0 ; extra == 'full'
240
- Requires-Dist: dask[complete] >=2024.5.1 ; extra == 'full'
241
- Requires-Dist: partd >=1.4.2 ; extra == 'full'
242
- Requires-Dist: pytz ; extra == 'full'
243
- Requires-Dist: joblib >=0.17.0 ; extra == 'full'
244
- Requires-Dist: SQLAlchemy >=2.0.5 ; extra == 'full'
245
- Requires-Dist: databases >=0.4.0 ; extra == 'full'
246
- Requires-Dist: aiosqlite >=0.16.0 ; extra == 'full'
247
- Requires-Dist: asyncpg >=0.21.0 ; extra == 'full'
248
- Requires-Dist: Flask-Compress >=1.10.1 ; extra == 'full'
249
- Requires-Dist: dash >=2.6.2 ; extra == 'full'
250
- Requires-Dist: dash-bootstrap-components >=1.2.1 ; extra == 'full'
251
- Requires-Dist: dash-ace >=0.2.1 ; extra == 'full'
252
- Requires-Dist: dash-extensions >=1.0.4 ; extra == 'full'
253
- Requires-Dist: dash-daq >=0.5.0 ; extra == 'full'
254
- Requires-Dist: terminado >=0.12.1 ; extra == 'full'
255
- Requires-Dist: tornado >=6.1.0 ; extra == 'full'
256
- Requires-Dist: uvicorn[standard] >=0.29.0 ; extra == 'full'
257
- Requires-Dist: gunicorn >=22.0.0 ; extra == 'full'
258
- Requires-Dist: python-dotenv >=0.20.0 ; extra == 'full'
259
- Requires-Dist: websockets >=11.0.3 ; extra == 'full'
260
- Requires-Dist: fastapi >=0.111.0 ; extra == 'full'
261
- Requires-Dist: fastapi-login >=1.7.2 ; extra == 'full'
262
- Requires-Dist: python-multipart >=0.0.9 ; extra == 'full'
263
- Requires-Dist: httpx >=0.27.2 ; extra == 'full'
264
- Requires-Dist: httpcore >=1.0.6 ; extra == 'full'
265
- Requires-Dist: valkey >=6.0.0 ; extra == 'full'
266
- Provides-Extra: gui
267
- Requires-Dist: toga >=0.3.0-dev29 ; extra == 'gui'
268
- Requires-Dist: pywebview >=3.6.3 ; extra == 'gui'
269
- Requires-Dist: pycparser >=2.21.0 ; extra == 'gui'
270
- Provides-Extra: jobs
271
- Requires-Dist: dill >=0.3.3 ; extra == 'jobs'
272
- Requires-Dist: python-daemon >=0.2.3 ; extra == 'jobs'
273
- Requires-Dist: watchfiles >=0.21.0 ; extra == 'jobs'
274
- Requires-Dist: psutil >=5.8.0 ; extra == 'jobs'
275
- Provides-Extra: minimal
276
- Provides-Extra: required
277
- Provides-Extra: setup
278
- Provides-Extra: sql
279
- Requires-Dist: numpy >=1.18.5 ; extra == 'sql'
280
- Requires-Dist: pandas[parquet] >=2.0.1 ; extra == 'sql'
281
- Requires-Dist: pyarrow >=16.1.0 ; extra == 'sql'
282
- Requires-Dist: dask[complete] >=2024.5.1 ; extra == 'sql'
283
- Requires-Dist: partd >=1.4.2 ; extra == 'sql'
284
- Requires-Dist: pytz ; extra == 'sql'
285
- Requires-Dist: joblib >=0.17.0 ; extra == 'sql'
286
- Requires-Dist: SQLAlchemy >=2.0.5 ; extra == 'sql'
287
- Requires-Dist: databases >=0.4.0 ; extra == 'sql'
288
- Requires-Dist: aiosqlite >=0.16.0 ; extra == 'sql'
289
- Requires-Dist: asyncpg >=0.21.0 ; extra == 'sql'
290
- Requires-Dist: cryptography >=38.0.1 ; extra == 'sql'
291
- Requires-Dist: psycopg[binary] >=3.2.1 ; extra == 'sql'
292
- Requires-Dist: PyMySQL >=0.9.0 ; extra == 'sql'
293
- Requires-Dist: aiomysql >=0.0.21 ; extra == 'sql'
294
- Requires-Dist: sqlalchemy-cockroachdb >=2.0.0 ; extra == 'sql'
295
- Requires-Dist: duckdb >=1.0.0 ; extra == 'sql'
296
- Requires-Dist: duckdb-engine >=0.13.0 ; extra == 'sql'
297
- Requires-Dist: wheel >=0.34.2 ; extra == 'sql'
298
- Requires-Dist: setuptools >=63.3.0 ; extra == 'sql'
299
- Requires-Dist: PyYAML >=5.3.1 ; extra == 'sql'
300
- Requires-Dist: pip >=22.0.4 ; extra == 'sql'
301
- Requires-Dist: update-checker >=0.18.0 ; extra == 'sql'
302
- Requires-Dist: semver >=3.0.2 ; extra == 'sql'
303
- Requires-Dist: pathspec >=0.9.0 ; extra == 'sql'
304
- Requires-Dist: python-dateutil >=2.7.5 ; extra == 'sql'
305
- Requires-Dist: requests >=2.32.3 ; extra == 'sql'
306
- Requires-Dist: certifi >=2024.8.30 ; extra == 'sql'
307
- Requires-Dist: idna >=3.10.0 ; extra == 'sql'
308
- Requires-Dist: binaryornot >=0.4.4 ; extra == 'sql'
309
- Requires-Dist: pyvim >=3.0.2 ; extra == 'sql'
310
- Requires-Dist: ptpython >=3.0.27 ; extra == 'sql'
311
- Requires-Dist: aiofiles >=0.6.0 ; extra == 'sql'
312
- Requires-Dist: packaging >=21.3.0 ; extra == 'sql'
313
- Requires-Dist: prompt-toolkit >=3.0.39 ; extra == 'sql'
314
- Requires-Dist: more-itertools >=8.7.0 ; extra == 'sql'
315
- Requires-Dist: fasteners >=0.19.0 ; extra == 'sql'
316
- Requires-Dist: virtualenv >=20.1.0 ; extra == 'sql'
317
- Requires-Dist: attrs >=24.2.0 ; extra == 'sql'
318
- Requires-Dist: uv >=0.2.11 ; extra == 'sql'
319
- Provides-Extra: stack
320
- Requires-Dist: docker-compose >=1.29.2 ; extra == 'stack'
321
-
322
- <img src="https://meerschaum.io/assets/banner_1920x320.png" alt="Meerschaum banner" style="width: 100%"/>
323
-
324
- | PyPI | GitHub | Info | Stats |
325
- |---|---|---|---|
326
- | ![PyPI]( https://img.shields.io/pypi/v/meerschaum?color=%2300cc66&label=Version ) | ![GitHub Repo stars](https://img.shields.io/github/stars/bmeares/Meerschaum?style=social) | ![License](https://img.shields.io/github/license/bmeares/Meerschaum?label=License) | ![Number of plugins]( https://img.shields.io/badge/dynamic/json?color=3098c1&label=Public%20Plugins&query=num_plugins&url=https%3A%2F%2Fapi.mrsm.io%2Finfo ) |
327
- | ![PyPI - Python Version]( https://img.shields.io/pypi/pyversions/meerschaum?label=Python&logo=python&logoColor=%23ffffff ) | ![GitHub Sponsors](https://img.shields.io/github/sponsors/bmeares?color=eadf15&label=Sponsors) | [![Artifact Hub](https://img.shields.io/endpoint?url=https://artifacthub.io/badge/repository/meerschaum)](https://artifacthub.io/packages/search?repo=meerschaum) | ![Number of registered users]( https://img.shields.io/badge/dynamic/json?color=3098c1&label=Registered%20Users&query=num_users&url=https%3A%2F%2Fapi.mrsm.io%2Finfo ) |
328
-
329
- <p align="center">
330
- <img src="https://meerschaum.io/files/images/demo.gif" alt="Meerschaum demo" height="450px">
331
- </p>
332
-
333
- ## What is Meerschaum?
334
- Meerschaum is a tool for quickly synchronizing time-series data streams called **pipes**. With Meerschaum, you can have a data visualization stack running in minutes.
335
-
336
- <p align="center">
337
- <img src="https://meerschaum.io/assets/screenshots/weather_pipes.png"/>
338
- </p>
339
-
340
- ## Why Meerschaum?
341
-
342
- Two words: *incremental updates*. Fetch the data you need, and Meerschaum will handle the rest.
343
-
344
- If you've worked with time-series data, you know the headaches that come with ETL.
345
- Data engineering often gets in analysts' way, and when work needs to get done, every minute spent on pipelining is time taken away from real analysis.
346
-
347
- Rather than copy / pasting your ETL scripts, simply build pipes with Meerschaum! [Meerschaum gives you the tools to design your data streams how you like](https://towardsdatascience.com/easy-time-series-etl-for-data-scientists-with-meerschaum-5aade339b398) ― and don't worry — you can always incorporate Meerschaum into your existing systems!
348
-
349
- ### Want to Learn More?
350
-
351
- You can find a wealth of information at [meerschaum.io](https://meerschaum.io)!
352
-
353
- Additionally, below are several articles published about Meerschaum:
354
-
355
- - Interview featured in [*Console 100 - The Open Source Newsletter*](https://console.substack.com/p/console-100)
356
- - [*A Data Scientist's Guide to Fetching COVID-19 Data in 2022*](https://towardsdatascience.com/a-data-scientists-guide-to-fetching-covid-19-data-in-2022-d952b4697) (Towards Data Science)
357
- - [*Time-Series ETL with Meerschaum*](https://towardsdatascience.com/easy-time-series-etl-for-data-scientists-with-meerschaum-5aade339b398) (Towards Data Science)
358
- - [*How I automatically extract my M1 Finance transactions*](https://bmeares.medium.com/how-i-automatically-extract-my-m1-finance-transactions-b43cef857bc7)
359
-
360
- ## Installation
361
-
362
- For a more thorough setup guide, visit the [Getting Started](https://meerschaum.io/get-started/) page at [meerschaum.io](https://meerschaum.io).
363
-
364
- ### TL;DR
365
-
366
- ```bash
367
- pip install -U --user meerschaum
368
- mrsm stack up -d db grafana
369
- mrsm bootstrap pipes
370
- ```
371
-
372
- ## Usage
373
-
374
- Please visit [meerschaum.io](https://meerschaum.io) for setup, usage, and troubleshooting information. You can find technical documentation at [docs.meerschaum.io](https://docs.meerschaum.io), and here is a complete list of the [Meerschaum actions](https://meerschaum.io/reference/actions/).
375
-
376
- ### CLI
377
- ```bash
378
- ### Install the NOAA weather plugin.
379
- mrsm install plugin noaa
380
-
381
- ### Register a new pipe to the built-in SQLite DB.
382
- ### You can instead run `bootstrap pipe` for a wizard.
383
- ### Enter 'KATL' for Atlanta when prompted.
384
- mrsm register pipe -c plugin:noaa -m weather -l atl -i sql:local
385
-
386
- ### Pull data and create the table "plugin_noaa_weather_atl".
387
- mrsm sync pipes -l atl -i sql:local
388
- ```
389
-
390
- ### Python API
391
-
392
- ```python
393
- import meerschaum as mrsm
394
- pipe = mrsm.Pipe(
395
- 'foo', 'bar', ### Connector and metric labels.
396
- target = 'MyTableName!', ### Table name. Defaults to 'foo_bar'.
397
- instance = 'sql:local', ### Built-in SQLite DB. Defaults to 'sql:main'.
398
- columns = {
399
- 'datetime': 'dt', ### Column for the datetime index.
400
- 'id' : 'id', ### Column for the ID index (optional).
401
- },
402
- )
403
- ### Pass a DataFrame to create the table and indices.
404
- pipe.sync([{'dt': '2022-07-01', 'id': 1, 'val': 10}])
405
-
406
- ### Duplicate rows are ignored.
407
- pipe.sync([{'dt': '2022-07-01', 'id': 1, 'val': 10}])
408
- assert len(pipe.get_data()) == 1
409
-
410
- ### Rows with existing keys (datetime and/or id) are updated.
411
- pipe.sync([{'dt': '2022-07-01', 'id': 1, 'val': 100}])
412
- assert len(pipe.get_data()) == 1
413
-
414
- ### Translates to this query for SQLite:
415
- ###
416
- ### SELECT *
417
- ### FROM "MyTableName!"
418
- ### WHERE "dt" >= datetime('2022-01-01', '0 minute')
419
- ### AND "dt" < datetime('2023-01-01', '0 minute')
420
- ### AND "id" IN ('1')
421
- df = pipe.get_data(
422
- begin = '2022-01-01',
423
- end = '2023-01-01',
424
- params = {'id': [1]},
425
- )
426
-
427
- ### Shape of the DataFrame:
428
- ### dt id val
429
- ### 0 2022-07-01 1 100
430
-
431
- ### Drop the table and remove the pipe's metadata.
432
- pipe.delete()
433
- ```
434
-
435
- ### Simple Plugin
436
-
437
- ```python
438
- # ~/.config/plugins/example.py
439
-
440
- __version__ = '1.0.0'
441
- required = ['requests']
442
-
443
- def register(pipe, **kw):
444
- return {
445
- 'columns': {
446
- 'datetime': 'dt',
447
- 'id' : 'id',
448
- },
449
- }
450
-
451
- def fetch(pipe, **kw):
452
- import requests, datetime, random
453
- response = requests.get('http://date.jsontest.com/')
454
-
455
- ### The fetched JSON has the following shape:
456
- ### {
457
- ### "date": "07-01-2022",
458
- ### "milliseconds_since_epoch": 1656718801566,
459
- ### "time": "11:40:01 PM"
460
- ### }
461
- data = response.json()
462
- timestamp = datetime.datetime.fromtimestamp(
463
- int(str(data['milliseconds_since_epoch'])[:-3])
464
- )
465
-
466
- ### You may also return a Pandas DataFrame.
467
- return [{
468
- "dt" : timestamp,
469
- "id" : random.randint(1, 4),
470
- "value": random.uniform(1, 100),
471
- }]
472
- ```
473
-
474
- ## Features
475
-
476
- - 📊 **Built for Data Scientists and Analysts**
477
- - Integrate with Pandas, Grafana and other popular [data analysis tools](https://meerschaum.io/reference/data-analysis-tools/).
478
- - Persist your dataframes and always get the latest data.
479
- - ⚡️ **Production-Ready, Batteries Included**
480
- - [Synchronization engine](https://meerschaum.io/reference/pipes/syncing/) concurrently updates many time-series data streams.
481
- - One-click deploy a [TimescaleDB and Grafana stack](https://meerschaum.io/reference/stack/) for prototyping.
482
- - Serve data to your entire organization through the power of `uvicorn`, `gunicorn`, and `FastAPI`.
483
- - 🔌 **Easily Expandable**
484
- - Ingest any data source with a simple [plugin](https://meerschaum.io/reference/plugins/writing-plugins/). Just return a DataFrame, and Meerschaum handles the rest.
485
- - [Add any function as a command](https://meerschaum.io/reference/plugins/types-of-plugins/#action-plugins) to the Meerschaum system.
486
- - Include Meerschaum in your projects with its [easy-to-use Python API](https://docs.meerschaum.io).
487
- - ✨ **Tailored for Your Experience**
488
- - Rich CLI makes managing your data streams surprisingly enjoyable!
489
- - Web dashboard for those who prefer a more graphical experience.
490
- - Manage your database connections with [Meerschaum connectors](https://meerschaum.io/reference/connectors/).
491
- - Utility commands with sensible syntax let you control many pipes with grace.
492
- - 💼 **Portable from the Start**
493
- - The environment variable `$MRSM_ROOT_DIR` lets you emulate multiple installations and group together your [instances](https://meerschaum.io/reference/connectors/#instances-and-repositories).
494
- - No dependencies required; anything needed will be installed into a virtual environment.
495
- - [Specify required packages for your plugins](https://meerschaum.io/reference/plugins/writing-plugins/), and users will get those packages in a virtual environment.
496
-
497
- ## Support Meerschaum's Development
498
-
499
- For consulting services and to support Meerschaum's development, please considering sponsoring me on [GitHub sponsors](https://github.com/sponsors/bmeares).
500
-
501
- Additionally, you can always [buy me a coffee☕](https://www.buymeacoffee.com/bmeares)!
502
-
503
- ### License
504
-
505
- Copyright 2021 Bennett Meares
506
-
507
- Licensed under the Apache License, Version 2.0 (the "License");
508
- you may not use this file except in compliance with the License.
509
- You may obtain a copy of the License at
510
-
511
- http://www.apache.org/licenses/LICENSE-2.0
512
-
513
- Unless required by applicable law or agreed to in writing, software
514
- distributed under the License is distributed on an "AS IS" BASIS,
515
- WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
516
- See the License for the specific language governing permissions and
517
- limitations under the License.