xtn-tools-pro 1.0.0.0.5__py3-none-any.whl → 1.0.0.0.6__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.
- xtn_tools_pro/db/MongoDB.py +2 -2
- xtn_tools_pro/proxy/XiaoXiangProxy.py +1 -1
- xtn_tools_pro/tools.py +4 -157
- xtn_tools_pro/utils/crypto.py +87 -0
- xtn_tools_pro/utils/file_utils.py +42 -0
- xtn_tools_pro/utils/helpers.py +123 -0
- xtn_tools_pro/utils/log.py +1 -2
- xtn_tools_pro/utils/sql.py +1 -1
- xtn_tools_pro/utils/time_utils.py +143 -0
- {xtn_tools_pro-1.0.0.0.5.dist-info → xtn_tools_pro-1.0.0.0.6.dist-info}/METADATA +1 -1
- xtn_tools_pro-1.0.0.0.6.dist-info/RECORD +23 -0
- xtn_tools_pro-1.0.0.0.5.dist-info/RECORD +0 -19
- {xtn_tools_pro-1.0.0.0.5.dist-info → xtn_tools_pro-1.0.0.0.6.dist-info}/LICENSE +0 -0
- {xtn_tools_pro-1.0.0.0.5.dist-info → xtn_tools_pro-1.0.0.0.6.dist-info}/WHEEL +0 -0
- {xtn_tools_pro-1.0.0.0.5.dist-info → xtn_tools_pro-1.0.0.0.6.dist-info}/top_level.txt +0 -0
xtn_tools_pro/db/MongoDB.py
CHANGED
@@ -8,11 +8,11 @@
|
|
8
8
|
# --------------------------------------------------------------------------------------------------
|
9
9
|
# 2024/4/17 xiatn V00.01.000 新建
|
10
10
|
# --------------------------------------------------------------------------------------------------
|
11
|
-
from xtn_tools_pro.tools_time import *
|
12
11
|
from urllib import parse
|
12
|
+
from typing import List, Dict, Optional
|
13
|
+
from xtn_tools_pro.utils.time_utils import *
|
13
14
|
from pymongo import MongoClient as _MongoClient
|
14
15
|
from pymongo.database import Database as _Database
|
15
|
-
from typing import List, Dict, Optional
|
16
16
|
from pymongo.collection import Collection as _Collection
|
17
17
|
from pymongo.errors import DuplicateKeyError, BulkWriteError
|
18
18
|
|
@@ -10,7 +10,7 @@
|
|
10
10
|
# --------------------------------------------------------------------------------------------------
|
11
11
|
import requests, time, random
|
12
12
|
from xtn_tools_pro.db.RedisDB import RedisDBPro
|
13
|
-
from xtn_tools_pro.
|
13
|
+
from xtn_tools_pro.utils.time_utils import get_time_now_timestamp, get_time_now_day59_timestamp
|
14
14
|
|
15
15
|
import warnings
|
16
16
|
from urllib3.exceptions import InsecureRequestWarning
|
xtn_tools_pro/tools.py
CHANGED
@@ -8,169 +8,16 @@
|
|
8
8
|
# --------------------------------------------------------------------------------------------------
|
9
9
|
# 2024/4/17 xiatn V00.01.000 新建
|
10
10
|
# --------------------------------------------------------------------------------------------------
|
11
|
-
import hashlib, json, math,re
|
12
|
-
from pprint import pformat
|
13
|
-
from urllib.parse import urlencode
|
14
11
|
|
15
12
|
|
16
|
-
def
|
17
|
-
"""
|
18
|
-
获取文本的md5值 32位
|
19
|
-
:param s: 文本
|
20
|
-
:param is_upper: 是否转大写 默认False
|
21
|
-
:return:
|
22
|
-
"""
|
23
|
-
# s.encode()#变成bytes类型才能加密
|
24
|
-
m = hashlib.md5(s.encode()) # 长度是32
|
25
|
-
if is_upper:
|
26
|
-
return m.hexdigest().upper()
|
27
|
-
return m.hexdigest()
|
28
|
-
|
29
|
-
|
30
|
-
def get_md5_16(s, is_upper=False):
|
31
|
-
"""
|
32
|
-
获取文本的md5值 16位
|
33
|
-
:param s: 文本
|
34
|
-
:param is_upper: 是否转大写 默认False
|
35
|
-
:return:
|
36
|
-
"""
|
37
|
-
result = get_md5_32(s, is_upper)
|
38
|
-
return result[8:24]
|
39
|
-
|
40
|
-
|
41
|
-
def get_binary_content_md5_32(content, is_upper=False):
|
42
|
-
"""
|
43
|
-
二进制内容md5 例如图片
|
44
|
-
:param content: 二进制内容
|
45
|
-
:param is_upper: 是否转大写 默认False
|
46
|
-
:return:
|
47
|
-
"""
|
48
|
-
md5_hash = hashlib.md5(content)
|
49
|
-
md5_hexdigest = md5_hash.hexdigest()
|
50
|
-
if is_upper:
|
51
|
-
return md5_hexdigest.upper()
|
52
|
-
return md5_hexdigest
|
53
|
-
|
54
|
-
|
55
|
-
def get_binary_content_md5_16(content, is_upper=False):
|
56
|
-
"""
|
57
|
-
二进制内容md5 例如图片
|
58
|
-
:param content: 二进制内容
|
59
|
-
:param is_upper: 是否转大写 默认False
|
60
|
-
:return:
|
61
|
-
"""
|
62
|
-
result = get_binary_content_md5_32(content, is_upper)
|
63
|
-
return result[8:24]
|
64
|
-
|
65
|
-
|
66
|
-
def get_file_md5_32(file_path, is_upper=False):
|
67
|
-
"""
|
68
|
-
获取文件md5值
|
69
|
-
:param file_path: 文件路径
|
70
|
-
:param is_upper: 是否转大写 默认False
|
71
|
-
:return:
|
72
|
-
"""
|
73
|
-
with open(file_path, 'rb') as file:
|
74
|
-
data = file.read()
|
75
|
-
md5_hash = hashlib.md5(data).hexdigest()
|
76
|
-
if is_upper:
|
77
|
-
return md5_hash.upper()
|
78
|
-
return md5_hash
|
79
|
-
|
80
|
-
|
81
|
-
def get_file_md5_16(file_path, is_upper=False):
|
82
|
-
"""
|
83
|
-
获取文件md5值
|
84
|
-
:param file_path: 文件路径
|
85
|
-
:param is_upper: 是否转大写 默认False
|
86
|
-
:return:
|
87
|
-
"""
|
88
|
-
result = get_file_md5_32(file_path, is_upper)
|
89
|
-
return result[8:24]
|
90
|
-
|
91
|
-
|
92
|
-
def get_str_to_json(str_json):
|
93
|
-
"""
|
94
|
-
字符串类型的json格式 转 json
|
95
|
-
:param str_json: 字符串json
|
96
|
-
:return:
|
97
|
-
"""
|
98
|
-
try:
|
99
|
-
new_str_json = str_json.replace("'", '"'). \
|
100
|
-
replace("None", "null").replace("True", "true"). \
|
101
|
-
replace("False", "false")
|
102
|
-
return json.loads(new_str_json)
|
103
|
-
except Exception as e:
|
104
|
-
return {}
|
105
|
-
|
106
|
-
|
107
|
-
def get_build_url_with_params(url, params):
|
108
|
-
"""
|
109
|
-
传入url和params拼接完整的url ->效果 https://wwww.xxxx.com/?xxx1=1&xxx2=2
|
110
|
-
:param url:
|
111
|
-
:param params:
|
112
|
-
:return:
|
113
|
-
"""
|
114
|
-
encoded_params = urlencode(params)
|
115
|
-
full_url = url + "?" + encoded_params
|
116
|
-
return full_url
|
117
|
-
|
118
|
-
|
119
|
-
def get_calculate_total_page(total, limit):
|
120
|
-
"""
|
121
|
-
根据total和limit计算出一共有多少页
|
122
|
-
:param total:
|
123
|
-
:param limit:
|
124
|
-
:return:
|
125
|
-
"""
|
126
|
-
if limit <= 0:
|
127
|
-
return 0
|
128
|
-
# 根据总条数和limit计算总页数
|
129
|
-
total_pages = math.ceil(total / limit)
|
130
|
-
return total_pages
|
131
|
-
|
132
|
-
def list_to_strtuple(datas):
|
133
|
-
"""
|
134
|
-
列表转字符串
|
135
|
-
:param datas: datas: [1, 2]
|
136
|
-
:return: (1, 2) 字符串类型
|
137
|
-
"""
|
138
|
-
data_str = str(tuple(datas))
|
139
|
-
data_str = re.sub(",\)$", ")", data_str)
|
140
|
-
return data_str
|
141
|
-
|
142
|
-
|
143
|
-
|
144
|
-
|
145
|
-
def dumps_json(data,indent=4,sort_keys=False):
|
13
|
+
def split_image(img):
|
146
14
|
"""
|
147
|
-
|
148
|
-
:param
|
149
|
-
:param indent: 每一级嵌套都使用4个空格进行缩进
|
150
|
-
:param sort_keys: 是否排序
|
15
|
+
切割图片
|
16
|
+
:param img:
|
151
17
|
:return:
|
152
18
|
"""
|
153
|
-
try:
|
154
|
-
if isinstance(data, str):
|
155
|
-
data = get_str_to_json(data)
|
156
|
-
|
157
|
-
data = json.dumps(
|
158
|
-
data,
|
159
|
-
ensure_ascii=False,
|
160
|
-
indent=indent,
|
161
|
-
skipkeys=True,
|
162
|
-
sort_keys=sort_keys,
|
163
|
-
default=str,
|
164
|
-
)
|
165
|
-
|
166
|
-
except Exception as e:
|
167
|
-
data = pformat(data)
|
168
|
-
|
169
|
-
return data
|
170
|
-
|
171
|
-
|
172
|
-
def split_image(img):
|
173
19
|
pass
|
174
20
|
|
21
|
+
|
175
22
|
if __name__ == '__main__':
|
176
23
|
pass
|
@@ -0,0 +1,87 @@
|
|
1
|
+
#!/usr/bin/env python
|
2
|
+
# -*- coding: utf-8 -*-
|
3
|
+
|
4
|
+
# 说明:
|
5
|
+
# 加解密、编解码
|
6
|
+
# History:
|
7
|
+
# Date Author Version Modification
|
8
|
+
# --------------------------------------------------------------------------------------------------
|
9
|
+
# 2024/5/13 xiatn V00.01.000 新建
|
10
|
+
# --------------------------------------------------------------------------------------------------
|
11
|
+
import hashlib
|
12
|
+
|
13
|
+
|
14
|
+
def get_md5_32(s, is_upper=False):
|
15
|
+
"""
|
16
|
+
获取文本的md5值 32位
|
17
|
+
:param s: 文本
|
18
|
+
:param is_upper: 是否转大写 默认False
|
19
|
+
:return:
|
20
|
+
"""
|
21
|
+
# s.encode()#变成bytes类型才能加密
|
22
|
+
m = hashlib.md5(s.encode()) # 长度是32
|
23
|
+
if is_upper:
|
24
|
+
return m.hexdigest().upper()
|
25
|
+
return m.hexdigest()
|
26
|
+
|
27
|
+
|
28
|
+
def get_md5_16(s, is_upper=False):
|
29
|
+
"""
|
30
|
+
获取文本的md5值 16位
|
31
|
+
:param s: 文本
|
32
|
+
:param is_upper: 是否转大写 默认False
|
33
|
+
:return:
|
34
|
+
"""
|
35
|
+
result = get_md5_32(s, is_upper)
|
36
|
+
return result[8:24]
|
37
|
+
|
38
|
+
|
39
|
+
def get_binary_content_md5_32(content, is_upper=False):
|
40
|
+
"""
|
41
|
+
二进制内容md5 例如图片
|
42
|
+
:param content: 二进制内容
|
43
|
+
:param is_upper: 是否转大写 默认False
|
44
|
+
:return:
|
45
|
+
"""
|
46
|
+
md5_hash = hashlib.md5(content)
|
47
|
+
md5_hexdigest = md5_hash.hexdigest()
|
48
|
+
if is_upper:
|
49
|
+
return md5_hexdigest.upper()
|
50
|
+
return md5_hexdigest
|
51
|
+
|
52
|
+
|
53
|
+
def get_binary_content_md5_16(content, is_upper=False):
|
54
|
+
"""
|
55
|
+
二进制内容md5 例如图片
|
56
|
+
:param content: 二进制内容
|
57
|
+
:param is_upper: 是否转大写 默认False
|
58
|
+
:return:
|
59
|
+
"""
|
60
|
+
result = get_binary_content_md5_32(content, is_upper)
|
61
|
+
return result[8:24]
|
62
|
+
|
63
|
+
|
64
|
+
def get_file_md5_32(file_path, is_upper=False):
|
65
|
+
"""
|
66
|
+
获取文件md5值
|
67
|
+
:param file_path: 文件路径
|
68
|
+
:param is_upper: 是否转大写 默认False
|
69
|
+
:return:
|
70
|
+
"""
|
71
|
+
with open(file_path, 'rb') as file:
|
72
|
+
data = file.read()
|
73
|
+
md5_hash = hashlib.md5(data).hexdigest()
|
74
|
+
if is_upper:
|
75
|
+
return md5_hash.upper()
|
76
|
+
return md5_hash
|
77
|
+
|
78
|
+
|
79
|
+
def get_file_md5_16(file_path, is_upper=False):
|
80
|
+
"""
|
81
|
+
获取文件md5值
|
82
|
+
:param file_path: 文件路径
|
83
|
+
:param is_upper: 是否转大写 默认False
|
84
|
+
:return:
|
85
|
+
"""
|
86
|
+
result = get_file_md5_32(file_path, is_upper)
|
87
|
+
return result[8:24]
|
@@ -0,0 +1,42 @@
|
|
1
|
+
#!/usr/bin/env python
|
2
|
+
# -*- coding: utf-8 -*-
|
3
|
+
|
4
|
+
# 说明:
|
5
|
+
# 文件
|
6
|
+
# History:
|
7
|
+
# Date Author Version Modification
|
8
|
+
# --------------------------------------------------------------------------------------------------
|
9
|
+
# 2024/5/13 xiatn V00.01.000 新建
|
10
|
+
# --------------------------------------------------------------------------------------------------
|
11
|
+
import os
|
12
|
+
import re
|
13
|
+
|
14
|
+
|
15
|
+
def get_file_extension(file_name):
|
16
|
+
"""
|
17
|
+
根据文件名获取文件扩展名/后缀名
|
18
|
+
:param file_name: 文件名称
|
19
|
+
:return:
|
20
|
+
"""
|
21
|
+
_, file_extension = os.path.splitext(file_name)
|
22
|
+
return file_extension
|
23
|
+
|
24
|
+
|
25
|
+
def get_file_check_filename(file_name):
|
26
|
+
"""
|
27
|
+
传入文件名返回一个合法的文件名 会替换掉一些特殊符号 常用于爬虫写文件时文件名中带有特殊符号的情况...
|
28
|
+
:param filename: 文件名
|
29
|
+
:return:
|
30
|
+
"""
|
31
|
+
file_extension = get_file_extension(file_name)
|
32
|
+
# 删除非法字符
|
33
|
+
sanitized_filename = re.sub(r'[\/:*?"<>|]', '', file_name)
|
34
|
+
max_length = 255 # 操作系统限制文件名的最大长度为255个
|
35
|
+
sanitized_filename = sanitized_filename[:max_length]
|
36
|
+
return sanitized_filename
|
37
|
+
|
38
|
+
|
39
|
+
if __name__ == '__main__':
|
40
|
+
pass
|
41
|
+
print(get_file_extension('file/2024-04-19/BOSCH GEX 125-1A/125-1AE砂磨机操作说明书:[1]_jingyan.txt'))
|
42
|
+
print(get_file_check_filename('file/2024-04-19/BOSCH GEX 125-1A/125-1AE砂磨机操作说明书:[1]_jingyan.txt'))
|
@@ -0,0 +1,123 @@
|
|
1
|
+
#!/usr/bin/env python
|
2
|
+
# -*- coding: utf-8 -*-
|
3
|
+
|
4
|
+
# 说明:
|
5
|
+
# 杂七杂八
|
6
|
+
# History:
|
7
|
+
# Date Author Version Modification
|
8
|
+
# --------------------------------------------------------------------------------------------------
|
9
|
+
# 2024/5/13 xiatn V00.01.000 新建
|
10
|
+
# --------------------------------------------------------------------------------------------------
|
11
|
+
import re
|
12
|
+
import uuid
|
13
|
+
import math
|
14
|
+
import json
|
15
|
+
from uuid import UUID
|
16
|
+
from pprint import pformat
|
17
|
+
from urllib.parse import urlencode
|
18
|
+
|
19
|
+
|
20
|
+
def get_uuid(version=4, namespace: UUID = uuid.NAMESPACE_DNS, name=""):
|
21
|
+
"""
|
22
|
+
生成uuid
|
23
|
+
:param version:版本号
|
24
|
+
1:基于当前时间和 MAC 地址生成版本 1 的 UUID,具有唯一性,但可能存在一定的安全风险。
|
25
|
+
3:基于名称和命名空间的方式生成。它通过将名称和命名空间的标识符组合起来进行哈希计算,生成一个唯一的标识符。UUID 版本 3 使用的哈希算法是 MD5。
|
26
|
+
4:使用随机数生成版本 4 的 UUID,具有足够的随机性和唯一性。
|
27
|
+
5:使用基于命名空间和名称生成版本 5 的 UUID,可以使用自定义的命名空间和名称。
|
28
|
+
:param namespace:命名空间 uuid.NAMESPACE_DNS、uuid.NAMESPACE_URL、uuid.NAMESPACE_OID、uuid.NAMESPACE_X500
|
29
|
+
:param name:名称 自定义
|
30
|
+
:return:
|
31
|
+
"""
|
32
|
+
if version == 1:
|
33
|
+
result = uuid.uuid1()
|
34
|
+
elif version == 3:
|
35
|
+
result = uuid.uuid3(namespace, name)
|
36
|
+
elif version == 5:
|
37
|
+
result = uuid.uuid5(namespace, name)
|
38
|
+
else:
|
39
|
+
result = uuid.uuid4()
|
40
|
+
|
41
|
+
uuid_str = str(result)
|
42
|
+
# uuid_hex = uuid_obj.hex
|
43
|
+
# uuid_int = uuid_obj.int
|
44
|
+
# uuid_bytes = uuid_obj.bytes
|
45
|
+
return uuid_str
|
46
|
+
|
47
|
+
|
48
|
+
def get_str_to_json(str_json):
|
49
|
+
"""
|
50
|
+
字符串类型的json格式 转 json
|
51
|
+
:param str_json: 字符串json
|
52
|
+
:return:
|
53
|
+
"""
|
54
|
+
try:
|
55
|
+
new_str_json = str_json.replace("'", '"'). \
|
56
|
+
replace("None", "null").replace("True", "true"). \
|
57
|
+
replace("False", "false")
|
58
|
+
return json.loads(new_str_json)
|
59
|
+
except Exception as e:
|
60
|
+
return {}
|
61
|
+
|
62
|
+
|
63
|
+
def list_to_strtuple(datas):
|
64
|
+
"""
|
65
|
+
列表转字符串元组
|
66
|
+
:param datas: datas: [1, 2]
|
67
|
+
:return: (1, 2) 字符串类型
|
68
|
+
"""
|
69
|
+
data_str = str(tuple(datas))
|
70
|
+
data_str = re.sub(",\)$", ")", data_str)
|
71
|
+
return data_str
|
72
|
+
|
73
|
+
|
74
|
+
def dumps_json(data, indent=4, sort_keys=False):
|
75
|
+
"""
|
76
|
+
将JSON数据格式化为可打印的字符串
|
77
|
+
:param data:
|
78
|
+
:param indent: 每一级嵌套都使用4个空格进行缩进
|
79
|
+
:param sort_keys: 是否排序
|
80
|
+
:return:
|
81
|
+
"""
|
82
|
+
try:
|
83
|
+
if isinstance(data, str):
|
84
|
+
data = get_str_to_json(data)
|
85
|
+
|
86
|
+
data = json.dumps(
|
87
|
+
data,
|
88
|
+
ensure_ascii=False,
|
89
|
+
indent=indent,
|
90
|
+
skipkeys=True,
|
91
|
+
sort_keys=sort_keys,
|
92
|
+
default=str,
|
93
|
+
)
|
94
|
+
|
95
|
+
except Exception as e:
|
96
|
+
data = pformat(data)
|
97
|
+
|
98
|
+
return data
|
99
|
+
|
100
|
+
|
101
|
+
def get_calculate_total_page(total, limit):
|
102
|
+
"""
|
103
|
+
根据total和limit计算出一共有多少页
|
104
|
+
:param total:
|
105
|
+
:param limit:
|
106
|
+
:return:
|
107
|
+
"""
|
108
|
+
if limit <= 0:
|
109
|
+
return 0
|
110
|
+
# 根据总条数和limit计算总页数
|
111
|
+
total_pages = math.ceil(total / limit)
|
112
|
+
return total_pages
|
113
|
+
|
114
|
+
def get_build_url_with_params(url, params):
|
115
|
+
"""
|
116
|
+
传入url和params拼接完整的url ->效果 https://wwww.xxxx.com/?xxx1=1&xxx2=2
|
117
|
+
:param url:
|
118
|
+
:param params:
|
119
|
+
:return:
|
120
|
+
"""
|
121
|
+
encoded_params = urlencode(params)
|
122
|
+
full_url = url + "?" + encoded_params
|
123
|
+
return full_url
|
xtn_tools_pro/utils/log.py
CHANGED
@@ -10,11 +10,10 @@
|
|
10
10
|
# --------------------------------------------------------------------------------------------------
|
11
11
|
import os
|
12
12
|
import sys
|
13
|
-
import time
|
14
13
|
import inspect
|
15
14
|
import logging
|
16
|
-
from xtn_tools_pro.tools_time import get_time_timestamp_to_datestr
|
17
15
|
from logging.handlers import BaseRotatingHandler
|
16
|
+
from xtn_tools_pro.utils.time_utils import get_time_timestamp_to_datestr
|
18
17
|
|
19
18
|
|
20
19
|
class RotatingFileHandler(BaseRotatingHandler):
|
xtn_tools_pro/utils/sql.py
CHANGED
@@ -9,7 +9,7 @@
|
|
9
9
|
# 2024/5/12 xiatn V00.01.000 新建
|
10
10
|
# --------------------------------------------------------------------------------------------------
|
11
11
|
import datetime
|
12
|
-
from xtn_tools_pro.
|
12
|
+
from xtn_tools_pro.utils.helpers import list_to_strtuple, dumps_json
|
13
13
|
|
14
14
|
|
15
15
|
def format_sql_value(value):
|
@@ -0,0 +1,143 @@
|
|
1
|
+
#!/usr/bin/env python
|
2
|
+
# -*- coding: utf-8 -*-
|
3
|
+
|
4
|
+
# 说明:
|
5
|
+
# 时间
|
6
|
+
# History:
|
7
|
+
# Date Author Version Modification
|
8
|
+
# --------------------------------------------------------------------------------------------------
|
9
|
+
# 2024/5/13 xiatn V00.01.000 新建
|
10
|
+
# --------------------------------------------------------------------------------------------------
|
11
|
+
import time
|
12
|
+
import datetime
|
13
|
+
|
14
|
+
|
15
|
+
def get_time_now_timestamp(is_time_10=False, is_time_13=False):
|
16
|
+
"""
|
17
|
+
获取当前时间戳
|
18
|
+
:param is_time_10: 是否需要处理为10位的时间戳,默认不处理
|
19
|
+
:param is_time_13: 是否需要处理为13位的时间戳,默认不处理
|
20
|
+
:return:
|
21
|
+
"""
|
22
|
+
|
23
|
+
if is_time_10:
|
24
|
+
val = int(time.time())
|
25
|
+
elif is_time_13:
|
26
|
+
val = int(time.time() * 1000)
|
27
|
+
else:
|
28
|
+
val = time.time()
|
29
|
+
return val
|
30
|
+
|
31
|
+
|
32
|
+
def get_time_now_day0_timestamp(is_time_13=False):
|
33
|
+
"""
|
34
|
+
获取当天0点时间戳
|
35
|
+
:param is_time_13: 是否需要处理为13位的时间戳,默认不处理并且返回10位时间戳
|
36
|
+
:return:
|
37
|
+
"""
|
38
|
+
val = time.mktime(datetime.date.today().timetuple())
|
39
|
+
if is_time_13:
|
40
|
+
return int(val * 1000)
|
41
|
+
else:
|
42
|
+
return int(val)
|
43
|
+
|
44
|
+
|
45
|
+
def get_time_now_day59_timestamp(is_time_13=False):
|
46
|
+
"""
|
47
|
+
获取当天23:59:59点时间戳
|
48
|
+
:param is_time_13: 是否需要处理为13位的时间戳,默认不处理并且返回10位时间戳
|
49
|
+
:return:
|
50
|
+
"""
|
51
|
+
# 获取当前日期时间
|
52
|
+
now = datetime.datetime.now()
|
53
|
+
# 设置小时、分钟、秒为 23:59:59
|
54
|
+
last_second = now.replace(hour=23, minute=59, second=59)
|
55
|
+
# 转换为时间戳
|
56
|
+
timestamp = time.mktime(last_second.timetuple())
|
57
|
+
# 转换为整数类型
|
58
|
+
if is_time_13:
|
59
|
+
return get_time_10_to_13_timestamp(timestamp)
|
60
|
+
else:
|
61
|
+
return int(timestamp)
|
62
|
+
|
63
|
+
|
64
|
+
def get_time_x_day_timestamp(x, is_time_13=False):
|
65
|
+
"""
|
66
|
+
获取x天的0点的时间戳
|
67
|
+
:param x: 0:当天; 1:1天后; -1:一天前
|
68
|
+
:param is_time_13: 是否需要处理为13位的时间戳,默认不处理并且返回10位时间戳
|
69
|
+
:return:
|
70
|
+
"""
|
71
|
+
if x == 0:
|
72
|
+
date_string = datetime.datetime.now().strftime("%Y-%m-%d") # 当天日期
|
73
|
+
elif x > 0:
|
74
|
+
future_date = datetime.datetime.now() + datetime.timedelta(days=x)
|
75
|
+
date_string = future_date.strftime("%Y-%m-%d") # x天后的日期
|
76
|
+
else:
|
77
|
+
past_date = datetime.datetime.now() - datetime.timedelta(days=abs(x))
|
78
|
+
date_string = past_date.strftime("%Y-%m-%d") # x天前的日期
|
79
|
+
|
80
|
+
timestamp = get_time_datestr_to_timestamp(date_string=date_string, is_time_13=is_time_13)
|
81
|
+
return timestamp
|
82
|
+
|
83
|
+
|
84
|
+
def get_time_datestr_to_timestamp(date_string, date_format="%Y-%m-%d", is_time_13=False):
|
85
|
+
"""
|
86
|
+
根据日期格式转换为时间戳,date_string和date_format需要配合,自行传参修改,这里是以%Y-%m-%d为格式也就是2024-04-18
|
87
|
+
:param date_string: 字符串类型的日期格式 例如:2024-04-18
|
88
|
+
:param date_format: 时间格式
|
89
|
+
:param is_time_13: 是否需要处理为13位的时间戳,默认不处理并且返回10位时间戳
|
90
|
+
:return:
|
91
|
+
"""
|
92
|
+
date_obj = datetime.datetime.strptime(date_string, date_format)
|
93
|
+
timestamp = date_obj.timestamp()
|
94
|
+
if is_time_13:
|
95
|
+
return get_time_10_to_13_timestamp(timestamp)
|
96
|
+
else:
|
97
|
+
return int(timestamp)
|
98
|
+
|
99
|
+
|
100
|
+
def get_time_10_to_13_timestamp(timestamp):
|
101
|
+
"""
|
102
|
+
10位时间戳转13位时间戳
|
103
|
+
:param timestamp:
|
104
|
+
:return:
|
105
|
+
"""
|
106
|
+
val = int(timestamp)
|
107
|
+
if len(str(val)) == 10:
|
108
|
+
return int(val * 1000)
|
109
|
+
return val
|
110
|
+
|
111
|
+
|
112
|
+
def get_time_13_to_10_timestamp(timestamp):
|
113
|
+
"""
|
114
|
+
13位时间戳转10位时间戳
|
115
|
+
:param timestamp:
|
116
|
+
:return:
|
117
|
+
"""
|
118
|
+
val = int(timestamp)
|
119
|
+
if len(str(val)) == 13:
|
120
|
+
return int(val // 1000)
|
121
|
+
return val
|
122
|
+
|
123
|
+
|
124
|
+
def get_time_timestamp_to_datestr(format='%Y-%m-%d %H:%M:%S', now_time=0):
|
125
|
+
"""
|
126
|
+
根据时间戳转换为日期格式,兼容10位时间戳和13位时间戳
|
127
|
+
:param format: 日期格式,常用:%Y-%m-%d %H:%M:%S、%Y-%m-%d、%Y/%m/%d、%H:%M:%S ...
|
128
|
+
:param now_time: 时间戳,默认0表示当前时间戳
|
129
|
+
:return:
|
130
|
+
"""
|
131
|
+
# 根据格式获取当前转换好的时间
|
132
|
+
if not now_time:
|
133
|
+
now_time = get_time_now_timestamp()
|
134
|
+
now_time = get_time_13_to_10_timestamp(now_time)
|
135
|
+
val = time.strftime(format, time.localtime(now_time))
|
136
|
+
return val
|
137
|
+
|
138
|
+
|
139
|
+
if __name__ == '__main__':
|
140
|
+
pass
|
141
|
+
print(get_time_timestamp_to_datestr())
|
142
|
+
print(get_time_timestamp_to_datestr(format="%H:%M:%S", now_time=get_time_now_timestamp(is_time_10=True)))
|
143
|
+
print(get_time_timestamp_to_datestr(now_time=get_time_now_timestamp(is_time_13=True)))
|
@@ -0,0 +1,23 @@
|
|
1
|
+
xtn_tools_pro/__init__.py,sha256=26Tf9j2wj88M1Ldg3b1DJ40KyGgN9ZmQdBLuV453388,395
|
2
|
+
xtn_tools_pro/tools.py,sha256=KmOOrSnjZNJ3u9vFkMO3FX0DxtlW3fnI5fL4e_raCRs,542
|
3
|
+
xtn_tools_pro/tools_flie.py,sha256=-FID31G8AnV2u2djRO3Ae3Ei9ld9bSBWgzwqhYzZ5JQ,1517
|
4
|
+
xtn_tools_pro/tools_time.py,sha256=DMjsw9h4E_mrPsanPA8CEhpUE1AA6Z2FU4OJqJKZc1k,4867
|
5
|
+
xtn_tools_pro/db/MongoDB.py,sha256=zQLfZ-mhZWCFgY3dPF3dRAzAR3C8hrXO_yLZw9cUUUY,5573
|
6
|
+
xtn_tools_pro/db/MysqlDB.py,sha256=SBJrcjbZdxmtTKPGwl57NthPhs4uX8J3P6o_rK01O4k,13373
|
7
|
+
xtn_tools_pro/db/RedisDB.py,sha256=ep32Yj8AAkUHRshSBhKsdl06UwO7Z-gQJLaezspVRKw,6053
|
8
|
+
xtn_tools_pro/db/__init__.py,sha256=Zg91UWS02TO0Ba_0AY56s0oabRy93xLNFkpIIL_6mMM,416
|
9
|
+
xtn_tools_pro/proxy/XiaoXiangProxy.py,sha256=6jzGgN2t2zLPIKbSgN8seixwDLY4IjoZvB26f8yTUME,9848
|
10
|
+
xtn_tools_pro/proxy/__init__.py,sha256=WRwh6s2lruMu5buh0ejo9EK54kWT_VQhCsFGNFAmcyo,418
|
11
|
+
xtn_tools_pro/utils/__init__.py,sha256=I1_n_NP23F2lBqlF4EOlnOdLYxM8M4pbn63UhJN1hRE,418
|
12
|
+
xtn_tools_pro/utils/crypto.py,sha256=1hwpD3SW0PI2fa79-_Xh37ACzeeKFH775GiVTlp5xjA,2379
|
13
|
+
xtn_tools_pro/utils/file_utils.py,sha256=4Bmb1ISxqQC-7doPXDyY2o-H0m4upj_-hlLrO36sKJg,1509
|
14
|
+
xtn_tools_pro/utils/helpers.py,sha256=C6w0Nc8ngpWtdwyKDAACtobnAe-qQNVCRgk5n9iM0o8,3719
|
15
|
+
xtn_tools_pro/utils/log.py,sha256=8CRMiY7Q9LWGJLhfL0YfpANBwLets9f2qWfMOe5PpNM,8139
|
16
|
+
xtn_tools_pro/utils/retry.py,sha256=0wjHsR5DBBKpv4naMfxiky8kprrZes4WURIfFQ4H708,1657
|
17
|
+
xtn_tools_pro/utils/sql.py,sha256=EAKzbkZP7Q09j15Gm6o0_uq0qgQmcCQT6EAawbpp4v0,6263
|
18
|
+
xtn_tools_pro/utils/time_utils.py,sha256=TUtzG61PeVYXhaQd6pBrXAdlz7tBispNIRQRcGhE2No,4859
|
19
|
+
xtn_tools_pro-1.0.0.0.6.dist-info/LICENSE,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
20
|
+
xtn_tools_pro-1.0.0.0.6.dist-info/METADATA,sha256=1vth1IfbsqTpVsmz24eaHlsUlxX2apH9eUz2gMdRjKs,431
|
21
|
+
xtn_tools_pro-1.0.0.0.6.dist-info/WHEEL,sha256=oiQVh_5PnQM0E3gPdiz09WCNmwiHDMaGer_elqB3coM,92
|
22
|
+
xtn_tools_pro-1.0.0.0.6.dist-info/top_level.txt,sha256=jyB3FLDEr8zE1U7wHczTgIbvUpALhR-ULF7RVEO7O2U,14
|
23
|
+
xtn_tools_pro-1.0.0.0.6.dist-info/RECORD,,
|
@@ -1,19 +0,0 @@
|
|
1
|
-
xtn_tools_pro/__init__.py,sha256=26Tf9j2wj88M1Ldg3b1DJ40KyGgN9ZmQdBLuV453388,395
|
2
|
-
xtn_tools_pro/tools.py,sha256=xOqTL7jrJvmsPZBiUizKe7yWkmqvEbt-WGylGswNcQ8,4457
|
3
|
-
xtn_tools_pro/tools_flie.py,sha256=-FID31G8AnV2u2djRO3Ae3Ei9ld9bSBWgzwqhYzZ5JQ,1517
|
4
|
-
xtn_tools_pro/tools_time.py,sha256=DMjsw9h4E_mrPsanPA8CEhpUE1AA6Z2FU4OJqJKZc1k,4867
|
5
|
-
xtn_tools_pro/db/MongoDB.py,sha256=_GiX1MHNl9CtI-uLDgY_NmMSvRJei-mtKq3Hhe6ly1E,5567
|
6
|
-
xtn_tools_pro/db/MysqlDB.py,sha256=SBJrcjbZdxmtTKPGwl57NthPhs4uX8J3P6o_rK01O4k,13373
|
7
|
-
xtn_tools_pro/db/RedisDB.py,sha256=ep32Yj8AAkUHRshSBhKsdl06UwO7Z-gQJLaezspVRKw,6053
|
8
|
-
xtn_tools_pro/db/__init__.py,sha256=Zg91UWS02TO0Ba_0AY56s0oabRy93xLNFkpIIL_6mMM,416
|
9
|
-
xtn_tools_pro/proxy/XiaoXiangProxy.py,sha256=xrEBJZ6Cjuh6IBZVB17oXHwByaeKcWVUSSWSg17tujE,9842
|
10
|
-
xtn_tools_pro/proxy/__init__.py,sha256=WRwh6s2lruMu5buh0ejo9EK54kWT_VQhCsFGNFAmcyo,418
|
11
|
-
xtn_tools_pro/utils/__init__.py,sha256=I1_n_NP23F2lBqlF4EOlnOdLYxM8M4pbn63UhJN1hRE,418
|
12
|
-
xtn_tools_pro/utils/log.py,sha256=bSuPsGKVBbGLT5hmIcfRi9TeuJApALcPa1qGMrCHk24,8146
|
13
|
-
xtn_tools_pro/utils/retry.py,sha256=0wjHsR5DBBKpv4naMfxiky8kprrZes4WURIfFQ4H708,1657
|
14
|
-
xtn_tools_pro/utils/sql.py,sha256=YSDx2BxkQk-QA6RGBiImR9bbT4WyKDiCYU8Q4ZdaMG0,6255
|
15
|
-
xtn_tools_pro-1.0.0.0.5.dist-info/LICENSE,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
16
|
-
xtn_tools_pro-1.0.0.0.5.dist-info/METADATA,sha256=JAHmDIpLXqWb8Y5SoEso1ss7gh09BfnMEhmUIBc_D6c,431
|
17
|
-
xtn_tools_pro-1.0.0.0.5.dist-info/WHEEL,sha256=oiQVh_5PnQM0E3gPdiz09WCNmwiHDMaGer_elqB3coM,92
|
18
|
-
xtn_tools_pro-1.0.0.0.5.dist-info/top_level.txt,sha256=jyB3FLDEr8zE1U7wHczTgIbvUpALhR-ULF7RVEO7O2U,14
|
19
|
-
xtn_tools_pro-1.0.0.0.5.dist-info/RECORD,,
|
File without changes
|
File without changes
|
File without changes
|