-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathmisc.py
More file actions
70 lines (57 loc) · 1.91 KB
/
misc.py
File metadata and controls
70 lines (57 loc) · 1.91 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
from datetime import datetime
import json
message = "Esakkiraja"
def extract_input_params(args, kwargs):
extracted_params = {}
for key, value in kwargs.items():
if hasattr(value, "__dict__"):
extracted_params[key] = json.dumps(vars(value))
else:
extracted_params[key] = value
for i, value in enumerate(args):
if hasattr(value, "__dict__"):
extracted_params[f"arg{i}"] = json.dumps(vars(value))
else:
extracted_params[f"arg{i}"] = value
# Remove None values
return {k: v for k, v in extracted_params.items() if v is not None}
print("test");
def to_iso_format(value):
return (
None
if value is None
else (
value.isoformat(timespec="microseconds") + "Z"
if isinstance(value, datetime)
else None
)
)
def serialize_kwargs(**kwargs):
# Function to check if a value is serializable
def is_serializable(value):
try:
json.dumps(value)
return True
except (TypeError, ValueError):
return False
# Filter out non-serializable items
serializable_kwargs = {k: v for k, v in kwargs.items() if is_serializable(v)}
# Convert to string representation
return json.dumps(serializable_kwargs)
def serialize_args(*args):
# Function to check if a value is serializable
def is_serializable(value):
try:
json.dumps(value)
return True
except (TypeError, ValueError):
return False
# Filter out non-serializable items
serializable_args = [arg for arg in args if is_serializable(arg)]
# Convert to string representation
return json.dumps(serializable_args)
class datetime_encoder(json.JSONEncoder):
def default(self, o):
if isinstance(o, datetime):
return o.isoformat()
return json.JSONEncoder.default(self, o)