meerschaum 1.7.1__py3-none-any.whl → 1.7.3__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.
Files changed (31) hide show
  1. meerschaum/_internal/arguments/_parser.py +1 -1
  2. meerschaum/actions/api.py +3 -2
  3. meerschaum/actions/stack.py +5 -9
  4. meerschaum/api/dash/components.py +2 -2
  5. meerschaum/api/routes/_misc.py +27 -1
  6. meerschaum/config/__init__.py +4 -4
  7. meerschaum/config/_edit.py +10 -20
  8. meerschaum/config/_read_config.py +11 -12
  9. meerschaum/config/_sync.py +44 -75
  10. meerschaum/config/_version.py +1 -1
  11. meerschaum/config/stack/__init__.py +31 -21
  12. meerschaum/config/static/__init__.py +7 -2
  13. meerschaum/connectors/api/_actions.py +2 -2
  14. meerschaum/connectors/api/_login.py +2 -2
  15. meerschaum/connectors/api/_misc.py +6 -26
  16. meerschaum/connectors/api/_plugins.py +4 -5
  17. meerschaum/connectors/api/_users.py +14 -14
  18. meerschaum/connectors/parse.py +2 -2
  19. meerschaum/connectors/sql/_users.py +1 -1
  20. meerschaum/core/User/_User.py +7 -3
  21. meerschaum/utils/venv/_Venv.py +2 -0
  22. meerschaum/utils/venv/__init__.py +14 -9
  23. meerschaum-1.7.3.dist-info/METADATA +500 -0
  24. {meerschaum-1.7.1.dist-info → meerschaum-1.7.3.dist-info}/RECORD +30 -30
  25. {meerschaum-1.7.1.dist-info → meerschaum-1.7.3.dist-info}/WHEEL +1 -1
  26. meerschaum-1.7.1.dist-info/METADATA +0 -499
  27. {meerschaum-1.7.1.dist-info → meerschaum-1.7.3.dist-info}/LICENSE +0 -0
  28. {meerschaum-1.7.1.dist-info → meerschaum-1.7.3.dist-info}/NOTICE +0 -0
  29. {meerschaum-1.7.1.dist-info → meerschaum-1.7.3.dist-info}/entry_points.txt +0 -0
  30. {meerschaum-1.7.1.dist-info → meerschaum-1.7.3.dist-info}/top_level.txt +0 -0
  31. {meerschaum-1.7.1.dist-info → meerschaum-1.7.3.dist-info}/zip-safe +0 -0
@@ -1,499 +0,0 @@
1
- Metadata-Version: 2.1
2
- Name: meerschaum
3
- Version: 1.7.1
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.8
24
- Classifier: Programming Language :: Python :: 3.9
25
- Classifier: Programming Language :: Python :: 3.10
26
- Classifier: Programming Language :: Python :: 3.11
27
- Classifier: Topic :: Database
28
- Classifier: Natural Language :: English
29
- Requires-Python: >=3.8
30
- Description-Content-Type: text/markdown
31
- License-File: LICENSE
32
- License-File: NOTICE
33
- Provides-Extra: _drivers
34
- Requires-Dist: pyodbc (>=4.0.30) ; extra == '_drivers'
35
- Requires-Dist: cx-Oracle (>=8.3.0) ; extra == '_drivers'
36
- Provides-Extra: _required
37
- Requires-Dist: wheel (>=0.34.2) ; extra == '_required'
38
- Requires-Dist: setuptools (>=63.3.0) ; extra == '_required'
39
- Requires-Dist: PyYAML (>=5.3.1) ; extra == '_required'
40
- Requires-Dist: pip (>=22.0.4) ; extra == '_required'
41
- Requires-Dist: update-checker (>=0.18.0) ; extra == '_required'
42
- Requires-Dist: semver (>=3.0.0-dev4) ; extra == '_required'
43
- Requires-Dist: pathspec (>=0.9.0) ; extra == '_required'
44
- Requires-Dist: python-dateutil (>=2.7.5) ; extra == '_required'
45
- Requires-Dist: requests (>=2.23.0) ; extra == '_required'
46
- Requires-Dist: binaryornot (>=0.4.4) ; extra == '_required'
47
- Requires-Dist: pyvim (>=3.0.2) ; extra == '_required'
48
- Requires-Dist: aiofiles (>=0.6.0) ; extra == '_required'
49
- Requires-Dist: packaging (>=21.3.0) ; extra == '_required'
50
- Requires-Dist: prompt-toolkit (>=3.0.39) ; extra == '_required'
51
- Requires-Dist: more-itertools (>=8.7.0) ; extra == '_required'
52
- Requires-Dist: daemoniker (>=0.2.3) ; extra == '_required'
53
- Requires-Dist: psutil (>=5.8.0) ; extra == '_required'
54
- Requires-Dist: watchgod (>=0.7.0) ; extra == '_required'
55
- Requires-Dist: dill (>=0.3.3) ; extra == '_required'
56
- Requires-Dist: virtualenv (>=20.1.0) ; extra == '_required'
57
- Requires-Dist: rocketry (>=2.5.1) ; extra == '_required'
58
- Provides-Extra: api
59
- Requires-Dist: uvicorn[standard] (>=0.22.0) ; extra == 'api'
60
- Requires-Dist: gunicorn (>=20.1.0) ; extra == 'api'
61
- Requires-Dist: python-dotenv (>=0.20.0) ; extra == 'api'
62
- Requires-Dist: websockets (>=11.0.3) ; extra == 'api'
63
- Requires-Dist: fastapi (>=0.100.0) ; extra == 'api'
64
- Requires-Dist: passlib (>=1.7.4) ; extra == 'api'
65
- Requires-Dist: fastapi-login (>=1.7.2) ; extra == 'api'
66
- Requires-Dist: python-multipart (>=0.0.5) ; extra == 'api'
67
- Requires-Dist: pydantic (>=1.7.4) ; extra == 'api'
68
- Requires-Dist: httpx (>=0.24.1) ; extra == 'api'
69
- Requires-Dist: numpy (>=1.18.5) ; extra == 'api'
70
- Requires-Dist: pandas (>=1.5.3) ; extra == 'api'
71
- Requires-Dist: pytz (>=2022.1.0) ; extra == 'api'
72
- Requires-Dist: joblib (>=0.17.0) ; extra == 'api'
73
- Requires-Dist: SQLAlchemy (>=2.0.5) ; extra == 'api'
74
- Requires-Dist: databases (>=0.4.0) ; extra == 'api'
75
- Requires-Dist: aiosqlite (>=0.16.0) ; extra == 'api'
76
- Requires-Dist: asyncpg (>=0.21.0) ; extra == 'api'
77
- Requires-Dist: cryptography (>=38.0.1) ; extra == 'api'
78
- Requires-Dist: psycopg2-binary (>=2.8.6) ; extra == 'api'
79
- Requires-Dist: PyMySQL (>=0.9.0) ; extra == 'api'
80
- Requires-Dist: aiomysql (>=0.0.21) ; extra == 'api'
81
- Requires-Dist: sqlalchemy-cockroachdb (>=2.0.0) ; extra == 'api'
82
- Requires-Dist: duckdb (>=0.7.1) ; extra == 'api'
83
- Requires-Dist: duckdb-engine (>=0.7.0) ; extra == 'api'
84
- Requires-Dist: wheel (>=0.34.2) ; extra == 'api'
85
- Requires-Dist: setuptools (>=63.3.0) ; extra == 'api'
86
- Requires-Dist: PyYAML (>=5.3.1) ; extra == 'api'
87
- Requires-Dist: pip (>=22.0.4) ; extra == 'api'
88
- Requires-Dist: update-checker (>=0.18.0) ; extra == 'api'
89
- Requires-Dist: semver (>=3.0.0-dev4) ; extra == 'api'
90
- Requires-Dist: pathspec (>=0.9.0) ; extra == 'api'
91
- Requires-Dist: python-dateutil (>=2.7.5) ; extra == 'api'
92
- Requires-Dist: requests (>=2.23.0) ; extra == 'api'
93
- Requires-Dist: binaryornot (>=0.4.4) ; extra == 'api'
94
- Requires-Dist: pyvim (>=3.0.2) ; extra == 'api'
95
- Requires-Dist: aiofiles (>=0.6.0) ; extra == 'api'
96
- Requires-Dist: packaging (>=21.3.0) ; extra == 'api'
97
- Requires-Dist: prompt-toolkit (>=3.0.39) ; extra == 'api'
98
- Requires-Dist: more-itertools (>=8.7.0) ; extra == 'api'
99
- Requires-Dist: daemoniker (>=0.2.3) ; extra == 'api'
100
- Requires-Dist: psutil (>=5.8.0) ; extra == 'api'
101
- Requires-Dist: watchgod (>=0.7.0) ; extra == 'api'
102
- Requires-Dist: dill (>=0.3.3) ; extra == 'api'
103
- Requires-Dist: virtualenv (>=20.1.0) ; extra == 'api'
104
- Requires-Dist: rocketry (>=2.5.1) ; extra == 'api'
105
- Requires-Dist: pprintpp (>=0.4.0) ; extra == 'api'
106
- Requires-Dist: asciitree (>=0.3.3) ; extra == 'api'
107
- Requires-Dist: typing-extensions (>=4.7.1) ; extra == 'api'
108
- Requires-Dist: pygments (>=2.7.2) ; extra == 'api'
109
- Requires-Dist: colorama (>=0.4.3) ; extra == 'api'
110
- Requires-Dist: rich (>=13.4.2) ; extra == 'api'
111
- Requires-Dist: more-termcolor (>=1.1.3) ; extra == 'api'
112
- Requires-Dist: humanfriendly (>=10.0.0) ; extra == 'api'
113
- Requires-Dist: Flask-Compress (>=1.10.1) ; extra == 'api'
114
- Requires-Dist: dash (>=2.6.2) ; extra == 'api'
115
- Requires-Dist: dash-bootstrap-components (>=1.2.1) ; extra == 'api'
116
- Requires-Dist: dash-ace (>=0.2.1) ; extra == 'api'
117
- Requires-Dist: dash-extensions (<1.0.2) ; extra == 'api'
118
- Requires-Dist: dash-daq (>=0.5.0) ; extra == 'api'
119
- Requires-Dist: terminado (>=0.12.1) ; extra == 'api'
120
- Requires-Dist: tornado (>=6.1.0) ; extra == 'api'
121
- Requires-Dist: tornado-xstatic (>=0.2.0) ; extra == 'api'
122
- Requires-Dist: XStatic (>=1.0.2) ; extra == 'api'
123
- Requires-Dist: XStatic-term.js (>=0.0.7) ; extra == 'api'
124
- Provides-Extra: build
125
- Requires-Dist: cx-Freeze (>=6.5.1) ; extra == 'build'
126
- Requires-Dist: pyinstaller (>=5.0.0-dev0) ; extra == 'build'
127
- Provides-Extra: cli
128
- Requires-Dist: pgcli (>=3.1.0) ; extra == 'cli'
129
- Requires-Dist: mycli (>=1.23.2) ; extra == 'cli'
130
- Requires-Dist: litecli (>=1.5.0) ; extra == 'cli'
131
- Requires-Dist: mssql-cli (>=1.0.0) ; extra == 'cli'
132
- Requires-Dist: gadwall (>=0.2.0) ; extra == 'cli'
133
- Provides-Extra: dash
134
- Requires-Dist: Flask-Compress (>=1.10.1) ; extra == 'dash'
135
- Requires-Dist: dash (>=2.6.2) ; extra == 'dash'
136
- Requires-Dist: dash-bootstrap-components (>=1.2.1) ; extra == 'dash'
137
- Requires-Dist: dash-ace (>=0.2.1) ; extra == 'dash'
138
- Requires-Dist: dash-extensions (<1.0.2) ; extra == 'dash'
139
- Requires-Dist: dash-daq (>=0.5.0) ; extra == 'dash'
140
- Requires-Dist: terminado (>=0.12.1) ; extra == 'dash'
141
- Requires-Dist: tornado (>=6.1.0) ; extra == 'dash'
142
- Requires-Dist: tornado-xstatic (>=0.2.0) ; extra == 'dash'
143
- Requires-Dist: XStatic (>=1.0.2) ; extra == 'dash'
144
- Requires-Dist: XStatic-term.js (>=0.0.7) ; extra == 'dash'
145
- Provides-Extra: dev-tools
146
- Requires-Dist: twine (>=3.2.0) ; extra == 'dev-tools'
147
- Requires-Dist: tuna (>=0.5.3) ; extra == 'dev-tools'
148
- Requires-Dist: snakeviz (>=2.1.0) ; extra == 'dev-tools'
149
- Requires-Dist: mypy (>=0.812.0) ; extra == 'dev-tools'
150
- Requires-Dist: pytest (>=6.2.2) ; extra == 'dev-tools'
151
- Requires-Dist: pytest-xdist (>=3.2.1) ; extra == 'dev-tools'
152
- Requires-Dist: heartrate (>=0.2.1) ; extra == 'dev-tools'
153
- Requires-Dist: py-heat (>=0.0.6) ; extra == 'dev-tools'
154
- Provides-Extra: docs
155
- Requires-Dist: mkdocs (>=1.1.2) ; extra == 'docs'
156
- Requires-Dist: mkdocs-material (>=6.2.5) ; extra == 'docs'
157
- Requires-Dist: mkdocs-material-extensions (>=1.0.3) ; extra == 'docs'
158
- Requires-Dist: mkdocs-autolinks-plugin (>=0.2.0) ; extra == 'docs'
159
- Requires-Dist: mkdocs-awesome-pages-plugin (>=2.5.0) ; extra == 'docs'
160
- Requires-Dist: mkdocs-section-index (>=0.3.3) ; extra == 'docs'
161
- Requires-Dist: mkdocs-linkcheck (>=1.0.6) ; extra == 'docs'
162
- Requires-Dist: mkdocs-redirects (>=1.0.4) ; extra == 'docs'
163
- Requires-Dist: jinja2 (==3.0.3) ; extra == 'docs'
164
- Provides-Extra: drivers
165
- Requires-Dist: cryptography (>=38.0.1) ; extra == 'drivers'
166
- Requires-Dist: psycopg2-binary (>=2.8.6) ; extra == 'drivers'
167
- Requires-Dist: PyMySQL (>=0.9.0) ; extra == 'drivers'
168
- Requires-Dist: aiomysql (>=0.0.21) ; extra == 'drivers'
169
- Requires-Dist: sqlalchemy-cockroachdb (>=2.0.0) ; extra == 'drivers'
170
- Requires-Dist: duckdb (>=0.7.1) ; extra == 'drivers'
171
- Requires-Dist: duckdb-engine (>=0.7.0) ; extra == 'drivers'
172
- Provides-Extra: extras
173
- Requires-Dist: cmd2 (>=1.4.0) ; extra == 'extras'
174
- Requires-Dist: ruamel.yaml (>=0.16.12) ; extra == 'extras'
175
- Requires-Dist: pandasgui (>=0.2.9) ; extra == 'extras'
176
- Requires-Dist: modin[ray] (>=0.8.3) ; extra == 'extras'
177
- Requires-Dist: nanoid (>=2.0.0) ; extra == 'extras'
178
- Requires-Dist: importlib-metadata (>=4.12.0) ; extra == 'extras'
179
- Provides-Extra: formatting
180
- Requires-Dist: pprintpp (>=0.4.0) ; extra == 'formatting'
181
- Requires-Dist: asciitree (>=0.3.3) ; extra == 'formatting'
182
- Requires-Dist: typing-extensions (>=4.7.1) ; extra == 'formatting'
183
- Requires-Dist: pygments (>=2.7.2) ; extra == 'formatting'
184
- Requires-Dist: colorama (>=0.4.3) ; extra == 'formatting'
185
- Requires-Dist: rich (>=13.4.2) ; extra == 'formatting'
186
- Requires-Dist: more-termcolor (>=1.1.3) ; extra == 'formatting'
187
- Requires-Dist: humanfriendly (>=10.0.0) ; extra == 'formatting'
188
- Provides-Extra: full
189
- Requires-Dist: pprintpp (>=0.4.0) ; extra == 'full'
190
- Requires-Dist: asciitree (>=0.3.3) ; extra == 'full'
191
- Requires-Dist: typing-extensions (>=4.7.1) ; extra == 'full'
192
- Requires-Dist: pygments (>=2.7.2) ; extra == 'full'
193
- Requires-Dist: colorama (>=0.4.3) ; extra == 'full'
194
- Requires-Dist: rich (>=13.4.2) ; extra == 'full'
195
- Requires-Dist: more-termcolor (>=1.1.3) ; extra == 'full'
196
- Requires-Dist: humanfriendly (>=10.0.0) ; extra == 'full'
197
- Requires-Dist: wheel (>=0.34.2) ; extra == 'full'
198
- Requires-Dist: setuptools (>=63.3.0) ; extra == 'full'
199
- Requires-Dist: PyYAML (>=5.3.1) ; extra == 'full'
200
- Requires-Dist: pip (>=22.0.4) ; extra == 'full'
201
- Requires-Dist: update-checker (>=0.18.0) ; extra == 'full'
202
- Requires-Dist: semver (>=3.0.0-dev4) ; extra == 'full'
203
- Requires-Dist: pathspec (>=0.9.0) ; extra == 'full'
204
- Requires-Dist: python-dateutil (>=2.7.5) ; extra == 'full'
205
- Requires-Dist: requests (>=2.23.0) ; extra == 'full'
206
- Requires-Dist: binaryornot (>=0.4.4) ; extra == 'full'
207
- Requires-Dist: pyvim (>=3.0.2) ; extra == 'full'
208
- Requires-Dist: aiofiles (>=0.6.0) ; extra == 'full'
209
- Requires-Dist: packaging (>=21.3.0) ; extra == 'full'
210
- Requires-Dist: prompt-toolkit (>=3.0.39) ; extra == 'full'
211
- Requires-Dist: more-itertools (>=8.7.0) ; extra == 'full'
212
- Requires-Dist: daemoniker (>=0.2.3) ; extra == 'full'
213
- Requires-Dist: psutil (>=5.8.0) ; extra == 'full'
214
- Requires-Dist: watchgod (>=0.7.0) ; extra == 'full'
215
- Requires-Dist: dill (>=0.3.3) ; extra == 'full'
216
- Requires-Dist: virtualenv (>=20.1.0) ; extra == 'full'
217
- Requires-Dist: rocketry (>=2.5.1) ; extra == 'full'
218
- Requires-Dist: cryptography (>=38.0.1) ; extra == 'full'
219
- Requires-Dist: psycopg2-binary (>=2.8.6) ; extra == 'full'
220
- Requires-Dist: PyMySQL (>=0.9.0) ; extra == 'full'
221
- Requires-Dist: aiomysql (>=0.0.21) ; extra == 'full'
222
- Requires-Dist: sqlalchemy-cockroachdb (>=2.0.0) ; extra == 'full'
223
- Requires-Dist: duckdb (>=0.7.1) ; extra == 'full'
224
- Requires-Dist: duckdb-engine (>=0.7.0) ; extra == 'full'
225
- Requires-Dist: toga (>=0.3.0-dev29) ; extra == 'full'
226
- Requires-Dist: pywebview (>=3.6.3) ; extra == 'full'
227
- Requires-Dist: pycparser (>=2.21.0) ; extra == 'full'
228
- Requires-Dist: numpy (>=1.18.5) ; extra == 'full'
229
- Requires-Dist: pandas (>=1.5.3) ; extra == 'full'
230
- Requires-Dist: pytz (>=2022.1.0) ; extra == 'full'
231
- Requires-Dist: joblib (>=0.17.0) ; extra == 'full'
232
- Requires-Dist: SQLAlchemy (>=2.0.5) ; extra == 'full'
233
- Requires-Dist: databases (>=0.4.0) ; extra == 'full'
234
- Requires-Dist: aiosqlite (>=0.16.0) ; extra == 'full'
235
- Requires-Dist: asyncpg (>=0.21.0) ; extra == 'full'
236
- Requires-Dist: Flask-Compress (>=1.10.1) ; extra == 'full'
237
- Requires-Dist: dash (>=2.6.2) ; extra == 'full'
238
- Requires-Dist: dash-bootstrap-components (>=1.2.1) ; extra == 'full'
239
- Requires-Dist: dash-ace (>=0.2.1) ; extra == 'full'
240
- Requires-Dist: dash-extensions (<1.0.2) ; extra == 'full'
241
- Requires-Dist: dash-daq (>=0.5.0) ; extra == 'full'
242
- Requires-Dist: terminado (>=0.12.1) ; extra == 'full'
243
- Requires-Dist: tornado (>=6.1.0) ; extra == 'full'
244
- Requires-Dist: tornado-xstatic (>=0.2.0) ; extra == 'full'
245
- Requires-Dist: XStatic (>=1.0.2) ; extra == 'full'
246
- Requires-Dist: XStatic-term.js (>=0.0.7) ; extra == 'full'
247
- Requires-Dist: uvicorn[standard] (>=0.22.0) ; extra == 'full'
248
- Requires-Dist: gunicorn (>=20.1.0) ; extra == 'full'
249
- Requires-Dist: python-dotenv (>=0.20.0) ; extra == 'full'
250
- Requires-Dist: websockets (>=11.0.3) ; extra == 'full'
251
- Requires-Dist: fastapi (>=0.100.0) ; extra == 'full'
252
- Requires-Dist: passlib (>=1.7.4) ; extra == 'full'
253
- Requires-Dist: fastapi-login (>=1.7.2) ; extra == 'full'
254
- Requires-Dist: python-multipart (>=0.0.5) ; extra == 'full'
255
- Requires-Dist: pydantic (>=1.7.4) ; extra == 'full'
256
- Requires-Dist: httpx (>=0.24.1) ; extra == 'full'
257
- Provides-Extra: gui
258
- Requires-Dist: toga (>=0.3.0-dev29) ; extra == 'gui'
259
- Requires-Dist: pywebview (>=3.6.3) ; extra == 'gui'
260
- Requires-Dist: pycparser (>=2.21.0) ; extra == 'gui'
261
- Provides-Extra: minimal
262
- Provides-Extra: required
263
- Provides-Extra: setup
264
- Provides-Extra: sql
265
- Requires-Dist: numpy (>=1.18.5) ; extra == 'sql'
266
- Requires-Dist: pandas (>=1.5.3) ; extra == 'sql'
267
- Requires-Dist: pytz (>=2022.1.0) ; extra == 'sql'
268
- Requires-Dist: joblib (>=0.17.0) ; extra == 'sql'
269
- Requires-Dist: SQLAlchemy (>=2.0.5) ; extra == 'sql'
270
- Requires-Dist: databases (>=0.4.0) ; extra == 'sql'
271
- Requires-Dist: aiosqlite (>=0.16.0) ; extra == 'sql'
272
- Requires-Dist: asyncpg (>=0.21.0) ; extra == 'sql'
273
- Requires-Dist: cryptography (>=38.0.1) ; extra == 'sql'
274
- Requires-Dist: psycopg2-binary (>=2.8.6) ; extra == 'sql'
275
- Requires-Dist: PyMySQL (>=0.9.0) ; extra == 'sql'
276
- Requires-Dist: aiomysql (>=0.0.21) ; extra == 'sql'
277
- Requires-Dist: sqlalchemy-cockroachdb (>=2.0.0) ; extra == 'sql'
278
- Requires-Dist: duckdb (>=0.7.1) ; extra == 'sql'
279
- Requires-Dist: duckdb-engine (>=0.7.0) ; extra == 'sql'
280
- Requires-Dist: wheel (>=0.34.2) ; extra == 'sql'
281
- Requires-Dist: setuptools (>=63.3.0) ; extra == 'sql'
282
- Requires-Dist: PyYAML (>=5.3.1) ; extra == 'sql'
283
- Requires-Dist: pip (>=22.0.4) ; extra == 'sql'
284
- Requires-Dist: update-checker (>=0.18.0) ; extra == 'sql'
285
- Requires-Dist: semver (>=3.0.0-dev4) ; extra == 'sql'
286
- Requires-Dist: pathspec (>=0.9.0) ; extra == 'sql'
287
- Requires-Dist: python-dateutil (>=2.7.5) ; extra == 'sql'
288
- Requires-Dist: requests (>=2.23.0) ; extra == 'sql'
289
- Requires-Dist: binaryornot (>=0.4.4) ; extra == 'sql'
290
- Requires-Dist: pyvim (>=3.0.2) ; extra == 'sql'
291
- Requires-Dist: aiofiles (>=0.6.0) ; extra == 'sql'
292
- Requires-Dist: packaging (>=21.3.0) ; extra == 'sql'
293
- Requires-Dist: prompt-toolkit (>=3.0.39) ; extra == 'sql'
294
- Requires-Dist: more-itertools (>=8.7.0) ; extra == 'sql'
295
- Requires-Dist: daemoniker (>=0.2.3) ; extra == 'sql'
296
- Requires-Dist: psutil (>=5.8.0) ; extra == 'sql'
297
- Requires-Dist: watchgod (>=0.7.0) ; extra == 'sql'
298
- Requires-Dist: dill (>=0.3.3) ; extra == 'sql'
299
- Requires-Dist: virtualenv (>=20.1.0) ; extra == 'sql'
300
- Requires-Dist: rocketry (>=2.5.1) ; extra == 'sql'
301
- Provides-Extra: stack
302
- Requires-Dist: docker-compose (>=1.27.4) ; extra == 'stack'
303
-
304
- <img src="https://meerschaum.io/assets/banner_1920x320.png" alt="Meerschaum banner"/>
305
-
306
- | PyPI | GitHub | Info | Stats |
307
- |---|---|---|---|
308
- | ![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 ) |
309
- | ![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) | [![meerschaum Tutorials](https://badges.openbase.com/python/tutorials/meerschaum.svg?token=2Yi8Oav9UZYWocO1ncwnIOnpUN5dTnUMWai7lAKTB+k=)](https://openbase.com/python/meerschaum?utm_source=embedded&amp;utm_medium=badge&amp;utm_campaign=rate-badge) | ![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 ) |
310
-
311
- <p align="center">
312
- <img src="https://meerschaum.io/files/images/demo.gif" alt="Meerschaum demo" height="450px">
313
- </p>
314
-
315
- ## What is Meerschaum?
316
- 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.
317
-
318
- <p align="center">
319
- <img src="https://meerschaum.io/assets/screenshots/weather_pipes.png"/>
320
- </p>
321
-
322
- ## Why Meerschaum?
323
-
324
- Two words: *incremental updates*. Fetch the data you need, and Meerschaum will handle the rest.
325
-
326
- If you've worked with time-series data, you know the headaches that come with ETL.
327
- 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.
328
-
329
- 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!
330
-
331
- ### Want to Learn More?
332
-
333
- You can find a wealth of information at [meerschaum.io](https://meerschaum.io)!
334
-
335
- Additionally, below are several articles published about Meerschaum:
336
-
337
- - Interview featured in [*Console 100 - The Open Source Newsletter*](https://console.substack.com/p/console-100)
338
- - [*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)
339
- - [*Time-Series ETL with Meerschaum*](https://towardsdatascience.com/easy-time-series-etl-for-data-scientists-with-meerschaum-5aade339b398) (Towards Data Science)
340
- - [*How I automatically extract my M1 Finance transactions*](https://bmeares.medium.com/how-i-automatically-extract-my-m1-finance-transactions-b43cef857bc7)
341
-
342
- ## Installation
343
-
344
- For a more thorough setup guide, visit the [Getting Started](https://meerschaum.io/get-started/) page at [meerschaum.io](https://meerschaum.io).
345
-
346
- ### TL;DR
347
-
348
- ```bash
349
- pip install -U --user meerschaum
350
- mrsm stack up -d db grafana
351
- mrsm bootstrap pipes
352
- ```
353
-
354
- ## Usage
355
-
356
- 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/).
357
-
358
- ### CLI
359
- ```bash
360
- ### Install the NOAA weather plugin.
361
- mrsm install plugin noaa
362
-
363
- ### Register a new pipe to the built-in SQLite DB.
364
- ### You can instead run `bootstrap pipe` for a wizard.
365
- ### Enter 'KATL' for Atlanta when prompted.
366
- mrsm register pipe -c plugin:noaa -m weather -l atl -i sql:local
367
-
368
- ### Pull data and create the table "plugin_noaa_weather_atl".
369
- mrsm sync pipes -l atl -i sql:local
370
- ```
371
-
372
- ### Python API
373
-
374
- ```python
375
- import meerschaum as mrsm
376
- pipe = mrsm.Pipe(
377
- 'foo', 'bar', ### Connector and metric labels.
378
- target = 'MyTableName!', ### Table name. Defaults to 'foo_bar'.
379
- instance = 'sql:local', ### Built-in SQLite DB. Defaults to 'sql:main'.
380
- columns = {
381
- 'datetime': 'dt', ### Column for the datetime index.
382
- 'id' : 'id', ### Column for the ID index (optional).
383
- },
384
- )
385
- ### Pass a DataFrame to create the table and indices.
386
- pipe.sync([{'dt': '2022-07-01', 'id': 1, 'val': 10}])
387
-
388
- ### Duplicate rows are ignored.
389
- pipe.sync([{'dt': '2022-07-01', 'id': 1, 'val': 10}])
390
- assert len(pipe.get_data()) == 1
391
-
392
- ### Rows with existing keys (datetime and/or id) are updated.
393
- pipe.sync([{'dt': '2022-07-01', 'id': 1, 'val': 100}])
394
- assert len(pipe.get_data()) == 1
395
-
396
- ### Translates to this query for SQLite:
397
- ###
398
- ### SELECT *
399
- ### FROM "MyTableName!"
400
- ### WHERE "dt" >= datetime('2022-01-01', '0 minute')
401
- ### AND "dt" < datetime('2023-01-01', '0 minute')
402
- ### AND "id" IN ('1')
403
- df = pipe.get_data(
404
- begin = '2022-01-01',
405
- end = '2023-01-01',
406
- params = {'id': [1]},
407
- )
408
-
409
- ### Shape of the DataFrame:
410
- ### dt id val
411
- ### 0 2022-07-01 1 100
412
-
413
- ### Drop the table and remove the pipe's metadata.
414
- pipe.delete()
415
- ```
416
-
417
- ### Simple Plugin
418
-
419
- ```python
420
- # ~/.config/plugins/example.py
421
-
422
- __version__ = '1.0.0'
423
- required = ['requests']
424
-
425
- def register(pipe, **kw):
426
- return {
427
- 'columns': {
428
- 'datetime': 'dt',
429
- 'id' : 'id',
430
- },
431
- }
432
-
433
- def fetch(pipe, **kw):
434
- import requests, datetime, random
435
- response = requests.get('http://date.jsontest.com/')
436
-
437
- ### The fetched JSON has the following shape:
438
- ### {
439
- ### "date": "07-01-2022",
440
- ### "milliseconds_since_epoch": 1656718801566,
441
- ### "time": "11:40:01 PM"
442
- ### }
443
- data = response.json()
444
- timestamp = datetime.datetime.fromtimestamp(
445
- int(str(data['milliseconds_since_epoch'])[:-3])
446
- )
447
-
448
- ### You may also return a Pandas DataFrame.
449
- return [{
450
- "dt" : timestamp,
451
- "id" : random.randint(1, 4),
452
- "value": random.uniform(1, 100),
453
- }]
454
- ```
455
-
456
- ## Features
457
-
458
- - 📊 **Built for Data Scientists and Analysts**
459
- - Integrate with Pandas, Grafana and other popular [data analysis tools](https://meerschaum.io/reference/data-analysis-tools/).
460
- - Persist your dataframes and always get the latest data.
461
- - ⚡️ **Production-Ready, Batteries Included**
462
- - [Synchronization engine](https://meerschaum.io/reference/pipes/syncing/) concurrently updates many time-series data streams.
463
- - One-click deploy a [TimescaleDB and Grafana stack](https://meerschaum.io/reference/stack/) for prototyping.
464
- - Serve data to your entire organization through the power of `uvicorn`, `gunicorn`, and `FastAPI`.
465
- - 🔌 **Easily Expandable**
466
- - Ingest any data source with a simple [plugin](https://meerschaum.io/reference/plugins/writing-plugins/). Just return a DataFrame, and Meerschaum handles the rest.
467
- - [Add any function as a command](https://meerschaum.io/reference/plugins/types-of-plugins/#action-plugins) to the Meerschaum system.
468
- - Include Meerschaum in your projects with its [easy-to-use Python API](https://docs.meerschaum.io).
469
- - ✨ **Tailored for Your Experience**
470
- - Rich CLI makes managing your data streams surprisingly enjoyable!
471
- - Web dashboard for those who prefer a more graphical experience.
472
- - Manage your database connections with [Meerschaum connectors](https://meerschaum.io/reference/connectors/).
473
- - Utility commands with sensible syntax let you control many pipes with grace.
474
- - 💼 **Portable from the Start**
475
- - The environment variable `$MRSM_ROOT_DIR` lets you emulate multiple installations and group together your [instances](https://meerschaum.io/reference/connectors/#instances-and-repositories).
476
- - No dependencies required; anything needed will be installed into a virtual environment.
477
- - [Specify required packages for your plugins](https://meerschaum.io/reference/plugins/writing-plugins/), and users will get those packages in a virtual environment.
478
-
479
- ## Support Meerschaum's Development
480
-
481
- For consulting services and to support Meerschaum's development, please considering sponsoring me on [GitHub sponsors](https://github.com/sponsors/bmeares).
482
-
483
- Additionally, you can always [buy me a coffee☕](https://www.buymeacoffee.com/bmeares)!
484
-
485
- ### License
486
-
487
- Copyright 2021 Bennett Meares
488
-
489
- Licensed under the Apache License, Version 2.0 (the "License");
490
- you may not use this file except in compliance with the License.
491
- You may obtain a copy of the License at
492
-
493
- http://www.apache.org/licenses/LICENSE-2.0
494
-
495
- Unless required by applicable law or agreed to in writing, software
496
- distributed under the License is distributed on an "AS IS" BASIS,
497
- WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
498
- See the License for the specific language governing permissions and
499
- limitations under the License.