|
|
|
|
|
|
|
import os |
|
from csv import DictReader |
|
|
|
from modules import scripts |
|
|
|
|
|
CSV_FILE_PATH = "csv/preset.tsv" |
|
MYPRESET_PATH = "csv/preset_own.tsv" |
|
HEADER = ["preset_name", "preset_weights"] |
|
path_root = scripts.basedir() |
|
|
|
|
|
class PresetWeights(): |
|
def __init__(self): |
|
self.presets = {} |
|
|
|
if os.path.exists(os.path.join(path_root, MYPRESET_PATH)): |
|
with open(os.path.join(path_root, MYPRESET_PATH), "r") as f: |
|
reader = DictReader(f, delimiter="\t") |
|
lines_dict = [row for row in reader] |
|
for line_dict in lines_dict: |
|
_w = ",".join([f"{x.strip()}" for x in line_dict["preset_weights"].split(",")]) |
|
self.presets.update({line_dict["preset_name"]: _w}) |
|
|
|
with open(os.path.join(path_root, CSV_FILE_PATH), "r") as f: |
|
reader = DictReader(f, delimiter="\t") |
|
lines_dict = [row for row in reader] |
|
for line_dict in lines_dict: |
|
_w = ",".join([f"{x.strip()}" for x in line_dict["preset_weights"].split(",")]) |
|
self.presets.update({line_dict["preset_name"]: _w}) |
|
|
|
def get_preset_name_list(self): |
|
return [k for k in self.presets.keys()] |
|
|
|
def find_weight_by_name(self, preset_name=""): |
|
if preset_name and preset_name != "" and preset_name in self.presets.keys(): |
|
return self.presets.get(preset_name, ",".join(["0.5" for _ in range(25)])) |
|
else: |
|
return "" |
|
|
|
def find_names_by_weight(self, weights=""): |
|
if weights and weights != "": |
|
if weights in self.presets.values(): |
|
return [k for k, v in self.presets.items() if v == weights] |
|
else: |
|
_val = ",".join([f"{x.strip()}" for x in weights.split(",")]) |
|
if _val in self.presets.values(): |
|
return [k for k, v in self.presets.items() if v == _val] |
|
else: |
|
return [] |
|
else: |
|
return [] |
|
|