lazysdk 0.1.118__tar.gz → 0.1.122__tar.gz
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.
- {lazysdk-0.1.118 → lazysdk-0.1.122}/PKG-INFO +11 -2
- {lazysdk-0.1.118 → lazysdk-0.1.122}/lazysdk/lazyexcel.py +14 -4
- {lazysdk-0.1.118 → lazysdk-0.1.122}/lazysdk/lazyfile.py +5 -1
- lazysdk-0.1.122/lazysdk/lazyhash.py +60 -0
- lazysdk-0.1.122/lazysdk/lazyjson.py +54 -0
- {lazysdk-0.1.118 → lazysdk-0.1.122}/lazysdk/lazytime.py +80 -0
- {lazysdk-0.1.118 → lazysdk-0.1.122}/lazysdk.egg-info/PKG-INFO +11 -2
- {lazysdk-0.1.118 → lazysdk-0.1.122}/lazysdk.egg-info/SOURCES.txt +1 -0
- {lazysdk-0.1.118 → lazysdk-0.1.122}/setup.py +1 -1
- lazysdk-0.1.118/lazysdk/lazyjson.py +0 -33
- {lazysdk-0.1.118 → lazysdk-0.1.122}/LICENSE +0 -0
- {lazysdk-0.1.118 → lazysdk-0.1.122}/README.md +0 -0
- {lazysdk-0.1.118 → lazysdk-0.1.122}/lazysdk/__init__.py +0 -0
- {lazysdk-0.1.118 → lazysdk-0.1.122}/lazysdk/lazyCrypto.py +0 -0
- {lazysdk-0.1.118 → lazysdk-0.1.122}/lazysdk/lazy_header.py +0 -0
- {lazysdk-0.1.118 → lazysdk-0.1.122}/lazysdk/lazy_id_card.py +0 -0
- {lazysdk-0.1.118 → lazysdk-0.1.122}/lazysdk/lazy_input.py +0 -0
- {lazysdk-0.1.118 → lazysdk-0.1.122}/lazysdk/lazybase64.py +0 -0
- {lazysdk-0.1.118 → lazysdk-0.1.122}/lazysdk/lazycache.py +0 -0
- {lazysdk-0.1.118 → lazysdk-0.1.122}/lazysdk/lazychromedriver.py +0 -0
- {lazysdk-0.1.118 → lazysdk-0.1.122}/lazysdk/lazydecode.py +0 -0
- {lazysdk-0.1.118 → lazysdk-0.1.122}/lazysdk/lazydict.py +0 -0
- {lazysdk-0.1.118 → lazysdk-0.1.122}/lazysdk/lazyenv.py +0 -0
- {lazysdk-0.1.118 → lazysdk-0.1.122}/lazysdk/lazyflask.py +0 -0
- {lazysdk-0.1.118 → lazysdk-0.1.122}/lazysdk/lazyhtml.py +0 -0
- {lazysdk-0.1.118 → lazysdk-0.1.122}/lazysdk/lazyid.py +0 -0
- {lazysdk-0.1.118 → lazysdk-0.1.122}/lazysdk/lazyinfo.py +0 -0
- {lazysdk-0.1.118 → lazysdk-0.1.122}/lazysdk/lazyip.py +0 -0
- {lazysdk-0.1.118 → lazysdk-0.1.122}/lazysdk/lazylist.py +0 -0
- {lazysdk-0.1.118 → lazysdk-0.1.122}/lazysdk/lazym3u8.py +0 -0
- {lazysdk-0.1.118 → lazysdk-0.1.122}/lazysdk/lazymd5.py +0 -0
- {lazysdk-0.1.118 → lazysdk-0.1.122}/lazysdk/lazypath.py +0 -0
- {lazysdk-0.1.118 → lazysdk-0.1.122}/lazysdk/lazyprocess.py +0 -0
- {lazysdk-0.1.118 → lazysdk-0.1.122}/lazysdk/lazyproxies.py +0 -0
- {lazysdk-0.1.118 → lazysdk-0.1.122}/lazysdk/lazyrandom.py +0 -0
- {lazysdk-0.1.118 → lazysdk-0.1.122}/lazysdk/lazyre.py +0 -0
- {lazysdk-0.1.118 → lazysdk-0.1.122}/lazysdk/lazyredis.py +0 -0
- {lazysdk-0.1.118 → lazysdk-0.1.122}/lazysdk/lazyrequests.py +0 -0
- {lazysdk-0.1.118 → lazysdk-0.1.122}/lazysdk/lazytext.py +0 -0
- {lazysdk-0.1.118 → lazysdk-0.1.122}/lazysdk/lazyua.py +0 -0
- {lazysdk-0.1.118 → lazysdk-0.1.122}/lazysdk/lazyurl.py +0 -0
- {lazysdk-0.1.118 → lazysdk-0.1.122}/lazysdk/lazywebhook.py +0 -0
- {lazysdk-0.1.118 → lazysdk-0.1.122}/lazysdk/lazywifi.py +0 -0
- {lazysdk-0.1.118 → lazysdk-0.1.122}/lazysdk/lazyxml.py +0 -0
- {lazysdk-0.1.118 → lazysdk-0.1.122}/lazysdk/showdata.py +0 -0
- {lazysdk-0.1.118 → lazysdk-0.1.122}/lazysdk.egg-info/dependency_links.txt +0 -0
- {lazysdk-0.1.118 → lazysdk-0.1.122}/lazysdk.egg-info/requires.txt +0 -0
- {lazysdk-0.1.118 → lazysdk-0.1.122}/lazysdk.egg-info/top_level.txt +0 -0
- {lazysdk-0.1.118 → lazysdk-0.1.122}/setup.cfg +0 -0
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
Metadata-Version: 2.
|
|
1
|
+
Metadata-Version: 2.4
|
|
2
2
|
Name: lazysdk
|
|
3
|
-
Version: 0.1.
|
|
3
|
+
Version: 0.1.122
|
|
4
4
|
Summary: 基于Python的懒人包
|
|
5
5
|
Home-page: https://gitee.com/ZeroSeeker/lazysdk
|
|
6
6
|
Author: ZeroSeeker
|
|
@@ -24,6 +24,15 @@ Requires-Dist: netifaces==0.11.0
|
|
|
24
24
|
Requires-Dist: user_agents==2.2.0
|
|
25
25
|
Requires-Dist: rich>=13.5.2
|
|
26
26
|
Requires-Dist: urllib3==1.26.9
|
|
27
|
+
Dynamic: author
|
|
28
|
+
Dynamic: author-email
|
|
29
|
+
Dynamic: classifier
|
|
30
|
+
Dynamic: description
|
|
31
|
+
Dynamic: description-content-type
|
|
32
|
+
Dynamic: home-page
|
|
33
|
+
Dynamic: license-file
|
|
34
|
+
Dynamic: requires-dist
|
|
35
|
+
Dynamic: summary
|
|
27
36
|
|
|
28
37
|
# lazysdk
|
|
29
38
|

|
|
@@ -252,12 +252,18 @@ def save_xlsx(
|
|
|
252
252
|
:param rank_asc: 排序列是否正序排序,True为按正序排序,False为按倒序排序
|
|
253
253
|
将输出保存后的文件绝对路径
|
|
254
254
|
"""
|
|
255
|
+
# 自动检查添加后缀
|
|
256
|
+
if file.endswith(".xlsx"):
|
|
257
|
+
pass
|
|
258
|
+
else:
|
|
259
|
+
file += ".xlsx"
|
|
260
|
+
|
|
255
261
|
if os.path.isabs(file): # 判断是否为绝对路径
|
|
256
262
|
pass
|
|
257
263
|
else:
|
|
258
264
|
file = os.getcwd() + path_separator + file
|
|
259
265
|
if value is None:
|
|
260
|
-
return
|
|
266
|
+
return file
|
|
261
267
|
else:
|
|
262
268
|
wb = openpyxl.Workbook()
|
|
263
269
|
sheet_index = 0 # sheet序号
|
|
@@ -363,9 +369,13 @@ def save_xlsx(
|
|
|
363
369
|
column=col_num,
|
|
364
370
|
value=value
|
|
365
371
|
)
|
|
366
|
-
|
|
367
|
-
|
|
368
|
-
|
|
372
|
+
|
|
373
|
+
# 对单元数据格式化
|
|
374
|
+
if cell_number_format:
|
|
375
|
+
value_cell_number_format = cell_number_format.get(key)
|
|
376
|
+
if value_cell_number_format:
|
|
377
|
+
cell.number_format = value_cell_number_format # 设置单元格数据格式
|
|
378
|
+
|
|
369
379
|
col_num += 1
|
|
370
380
|
row_num += 1
|
|
371
381
|
else:
|
|
@@ -169,7 +169,11 @@ def download(
|
|
|
169
169
|
if filename is None:
|
|
170
170
|
download_file_name = str(filename_default) + "." + str(suffix_name)
|
|
171
171
|
else:
|
|
172
|
-
|
|
172
|
+
if filename.endswith(suffix_name):
|
|
173
|
+
# 如果文件名中已存在后缀名,则不重复添加
|
|
174
|
+
download_file_name = filename
|
|
175
|
+
else:
|
|
176
|
+
download_file_name = str(filename) + "." + str(suffix_name)
|
|
173
177
|
|
|
174
178
|
if path is None:
|
|
175
179
|
path_local = download_file_name
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
#!/usr/bin/env python3
|
|
2
|
+
# coding = utf8
|
|
3
|
+
"""
|
|
4
|
+
@ Author : ZeroSeeker
|
|
5
|
+
@ e-mail : zeroseeker@foxmail.com
|
|
6
|
+
@ GitHub : https://github.com/ZeroSeeker
|
|
7
|
+
@ Gitee : https://gitee.com/ZeroSeeker
|
|
8
|
+
"""
|
|
9
|
+
import requests
|
|
10
|
+
import hashlib
|
|
11
|
+
|
|
12
|
+
|
|
13
|
+
def md5_file(
|
|
14
|
+
file_path: str = None,
|
|
15
|
+
file_url: str = None
|
|
16
|
+
):
|
|
17
|
+
"""
|
|
18
|
+
计算文件的md5
|
|
19
|
+
:param file_path: 本地文件路径
|
|
20
|
+
:param file_url: 网络文件地址
|
|
21
|
+
"""
|
|
22
|
+
# 文件名不影响md5
|
|
23
|
+
d5 = hashlib.md5()
|
|
24
|
+
if file_path:
|
|
25
|
+
with open(r'%s' % file_path, 'rb') as f:
|
|
26
|
+
while True:
|
|
27
|
+
data = f.read(2048)
|
|
28
|
+
if not data:
|
|
29
|
+
break
|
|
30
|
+
d5.update(data) # update添加时会进行计算
|
|
31
|
+
return d5.hexdigest()
|
|
32
|
+
elif file_url:
|
|
33
|
+
resp = requests.get(file_url)
|
|
34
|
+
d5.update(resp.content) # update添加时会进行计算
|
|
35
|
+
return d5.hexdigest()
|
|
36
|
+
else:
|
|
37
|
+
return
|
|
38
|
+
|
|
39
|
+
|
|
40
|
+
def md5_str(
|
|
41
|
+
content,
|
|
42
|
+
encoding='UTF-8'
|
|
43
|
+
):
|
|
44
|
+
d5 = hashlib.md5()
|
|
45
|
+
d5.update(content.encode(encoding=encoding)) # update添加时会进行计算
|
|
46
|
+
return d5.hexdigest()
|
|
47
|
+
|
|
48
|
+
|
|
49
|
+
def calculate_sha256(
|
|
50
|
+
content,
|
|
51
|
+
encoding: str='UTF-8'
|
|
52
|
+
):
|
|
53
|
+
"""
|
|
54
|
+
计算文档的SHA-256哈希值
|
|
55
|
+
:param content:
|
|
56
|
+
:param encoding:
|
|
57
|
+
:return: SHA-256哈希字符串
|
|
58
|
+
"""
|
|
59
|
+
# 使用BSON的JSON工具确保一致的序列化
|
|
60
|
+
return hashlib.sha256(content.encode(encoding)).hexdigest()
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
import json
|
|
2
|
+
import decimal
|
|
3
|
+
import datetime
|
|
4
|
+
import base64
|
|
5
|
+
|
|
6
|
+
|
|
7
|
+
class LazyEncoder(json.JSONEncoder):
|
|
8
|
+
def default(self, obj):
|
|
9
|
+
if isinstance(obj, decimal.Decimal):
|
|
10
|
+
return float(obj)
|
|
11
|
+
elif isinstance(obj, datetime.datetime):
|
|
12
|
+
# # 将datetime对象转换为ISO格式字符串
|
|
13
|
+
return obj.isoformat()
|
|
14
|
+
elif isinstance(obj, datetime.date):
|
|
15
|
+
return obj.isoformat()
|
|
16
|
+
elif isinstance(obj, bytes):
|
|
17
|
+
# 将bytes转换为base64编码的字符串
|
|
18
|
+
try:
|
|
19
|
+
# 尝试将bytes解码为UTF-8字符串
|
|
20
|
+
return obj.decode('utf-8')
|
|
21
|
+
except UnicodeDecodeError:
|
|
22
|
+
# 如果UTF-8解码失败,回退到Base64编码
|
|
23
|
+
return base64.b64encode(obj).decode('utf-8')
|
|
24
|
+
# elif isinstance(obj, bson.timestamp.Timestamp):
|
|
25
|
+
# # # 将BSON时间戳转换为其时间表示的ISO格式字符串
|
|
26
|
+
# return obj.as_datetime().isoformat()
|
|
27
|
+
# elif isinstance(obj, bson.objectid.ObjectId):
|
|
28
|
+
# # # 将ObjectId转换为字符串
|
|
29
|
+
# return str(obj)
|
|
30
|
+
return super(LazyEncoder, self).default(obj)
|
|
31
|
+
|
|
32
|
+
|
|
33
|
+
def json2str(
|
|
34
|
+
data: json,
|
|
35
|
+
ensure_ascii: bool = False
|
|
36
|
+
):
|
|
37
|
+
"""
|
|
38
|
+
在将json数据反序列化为str时,会遇到一些格式无法转换
|
|
39
|
+
这里使用识别类型转换转为str
|
|
40
|
+
目前支持类型:
|
|
41
|
+
|
|
42
|
+
对于mongodb返回数据的处理:
|
|
43
|
+
from bson import json_util
|
|
44
|
+
default=json_util.default
|
|
45
|
+
|
|
46
|
+
decimal --> str
|
|
47
|
+
datetime.datetime --> str(%Y-%m-%d %H:%M:%S)
|
|
48
|
+
datetime.date --> str(%Y-%m-%d)
|
|
49
|
+
"""
|
|
50
|
+
return json.dumps(
|
|
51
|
+
data,
|
|
52
|
+
cls=LazyEncoder,
|
|
53
|
+
ensure_ascii=ensure_ascii
|
|
54
|
+
)
|
|
@@ -1024,3 +1024,83 @@ def network_timestamp():
|
|
|
1024
1024
|
res = requests.get(url=url)
|
|
1025
1025
|
net_t = res.json()['data']['t'] # 精确到毫秒的时间戳
|
|
1026
1026
|
return int(net_t)
|
|
1027
|
+
|
|
1028
|
+
|
|
1029
|
+
def str2datetime(
|
|
1030
|
+
input_str,
|
|
1031
|
+
input_str_format: str = 'YYYYmmdd',
|
|
1032
|
+
output_str_format: str = '%Y-%m-%d %H:%M:%S.%f',
|
|
1033
|
+
):
|
|
1034
|
+
"""
|
|
1035
|
+
将输入的字符串按照既定格式格式化后输出
|
|
1036
|
+
:param input_str: 输入的字符串
|
|
1037
|
+
:param input_str_format: 输入的字符串格式,例如:YYmmdd
|
|
1038
|
+
:param output_str_format: 输出的字符串格式,例如:%Y-%m-%d %H:%M:%S.%f
|
|
1039
|
+
"""
|
|
1040
|
+
year_str = ""
|
|
1041
|
+
month_str = ""
|
|
1042
|
+
day_str = ""
|
|
1043
|
+
hour_str = ""
|
|
1044
|
+
minute_str = ""
|
|
1045
|
+
second_str = ""
|
|
1046
|
+
|
|
1047
|
+
for index in range(len(input_str_format)):
|
|
1048
|
+
index_str = input_str_format[index]
|
|
1049
|
+
if index_str == 'Y':
|
|
1050
|
+
year_str += input_str[index]
|
|
1051
|
+
elif index_str == 'm':
|
|
1052
|
+
month_str += input_str[index]
|
|
1053
|
+
elif index_str == 'd':
|
|
1054
|
+
day_str += input_str[index]
|
|
1055
|
+
elif index_str == 'H':
|
|
1056
|
+
hour_str += input_str[index]
|
|
1057
|
+
elif index_str == 'M':
|
|
1058
|
+
minute_str += input_str[index]
|
|
1059
|
+
elif index_str == 'S':
|
|
1060
|
+
second_str += input_str[index]
|
|
1061
|
+
else:
|
|
1062
|
+
continue
|
|
1063
|
+
|
|
1064
|
+
if year_str:
|
|
1065
|
+
year_int = int(year_str)
|
|
1066
|
+
else:
|
|
1067
|
+
year_int = None
|
|
1068
|
+
|
|
1069
|
+
if month_str:
|
|
1070
|
+
month_int = int(month_str)
|
|
1071
|
+
else:
|
|
1072
|
+
month_int = None
|
|
1073
|
+
|
|
1074
|
+
if day_str:
|
|
1075
|
+
day_int = int(day_str)
|
|
1076
|
+
else:
|
|
1077
|
+
day_int = None
|
|
1078
|
+
|
|
1079
|
+
if hour_str:
|
|
1080
|
+
hour_int = int(hour_str)
|
|
1081
|
+
else:
|
|
1082
|
+
hour_int = 0
|
|
1083
|
+
|
|
1084
|
+
if minute_str:
|
|
1085
|
+
minute_int = int(minute_str)
|
|
1086
|
+
else:
|
|
1087
|
+
minute_int = 0
|
|
1088
|
+
|
|
1089
|
+
if second_str:
|
|
1090
|
+
second_int = int(second_str)
|
|
1091
|
+
else:
|
|
1092
|
+
second_int = 0
|
|
1093
|
+
|
|
1094
|
+
return datetime.datetime(
|
|
1095
|
+
year=year_int,
|
|
1096
|
+
month=month_int,
|
|
1097
|
+
day=day_int,
|
|
1098
|
+
hour=hour_int,
|
|
1099
|
+
minute=minute_int,
|
|
1100
|
+
second=second_int
|
|
1101
|
+
).strftime(output_str_format)
|
|
1102
|
+
|
|
1103
|
+
|
|
1104
|
+
if __name__ == '__main__':
|
|
1105
|
+
res = str2datetime(input_str="20250101123456", input_str_format="YYYYmmdd")
|
|
1106
|
+
print(res)
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
Metadata-Version: 2.
|
|
1
|
+
Metadata-Version: 2.4
|
|
2
2
|
Name: lazysdk
|
|
3
|
-
Version: 0.1.
|
|
3
|
+
Version: 0.1.122
|
|
4
4
|
Summary: 基于Python的懒人包
|
|
5
5
|
Home-page: https://gitee.com/ZeroSeeker/lazysdk
|
|
6
6
|
Author: ZeroSeeker
|
|
@@ -24,6 +24,15 @@ Requires-Dist: netifaces==0.11.0
|
|
|
24
24
|
Requires-Dist: user_agents==2.2.0
|
|
25
25
|
Requires-Dist: rich>=13.5.2
|
|
26
26
|
Requires-Dist: urllib3==1.26.9
|
|
27
|
+
Dynamic: author
|
|
28
|
+
Dynamic: author-email
|
|
29
|
+
Dynamic: classifier
|
|
30
|
+
Dynamic: description
|
|
31
|
+
Dynamic: description-content-type
|
|
32
|
+
Dynamic: home-page
|
|
33
|
+
Dynamic: license-file
|
|
34
|
+
Dynamic: requires-dist
|
|
35
|
+
Dynamic: summary
|
|
27
36
|
|
|
28
37
|
# lazysdk
|
|
29
38
|

|
|
@@ -1,33 +0,0 @@
|
|
|
1
|
-
import json
|
|
2
|
-
import decimal
|
|
3
|
-
import datetime
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
class LazyEncoder(json.JSONEncoder):
|
|
7
|
-
def default(self, obj):
|
|
8
|
-
if isinstance(obj, decimal.Decimal):
|
|
9
|
-
return float(obj)
|
|
10
|
-
elif isinstance(obj, datetime.datetime):
|
|
11
|
-
return obj.strftime('%Y-%m-%d %H:%M:%S')
|
|
12
|
-
elif isinstance(obj, datetime.date):
|
|
13
|
-
return obj.strftime('%Y-%m-%d')
|
|
14
|
-
super(LazyEncoder, self).default(obj)
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
def json2str(
|
|
18
|
-
data: json,
|
|
19
|
-
ensure_ascii: bool = False
|
|
20
|
-
):
|
|
21
|
-
"""
|
|
22
|
-
在将json数据反序列化为str时,会遇到一些格式无法转换
|
|
23
|
-
这里使用识别类型转换转为str
|
|
24
|
-
目前支持类型:
|
|
25
|
-
decimal --> str
|
|
26
|
-
datetime.datetime --> str(%Y-%m-%d %H:%M:%S)
|
|
27
|
-
datetime.date --> str(%Y-%m-%d)
|
|
28
|
-
"""
|
|
29
|
-
return json.dumps(
|
|
30
|
-
data,
|
|
31
|
-
cls=LazyEncoder,
|
|
32
|
-
ensure_ascii=ensure_ascii
|
|
33
|
-
)
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|