- FeedforwardSupervisor: PvTag() ToUpperInvariant + empty FeedTag 가드 - FeedforwardConfigStore: 모든 ToLowerInvariant() 제거 - FeedRampAdvisorService: ToLowerInvariant 제거 + StringComparison.OrdinalIgnoreCase - SimOverrideStore: ToLowerInvariant 제거 - Hc900RealtimeService: HealthCheck SERVING 판정, mapping 없는 태그 대소문자 유지 - PidExtractorService: ToLowerInvariant → OrdinalIgnoreCase 비교 - Hc900Entities: 주석 업데이트 (대문자 표준) - load_state_labels.py: 소문자 변환 금지, controller_id 파라미터 추가 - Hc900Controllers: 대소문자 무시 정렬 - write.js: .MODE → AutoManState/RemLocSPState/SP_SelectState/TuneSetState - setup.js/html: 중복 함수 제거, C5 컨트롤러 placeholder
56 lines
1.8 KiB
Python
56 lines
1.8 KiB
Python
#!/usr/bin/env python3
|
|
"""
|
|
xlsx의 StatusPoint DescriptorState0~7 → hc900.tag_metadata 로드
|
|
실행: python3 scripts/load_state_labels.py [--controller C1]
|
|
태그명은 Experion ItemName 원형 대소문자 유지 (ToLower 금지).
|
|
"""
|
|
import openpyxl
|
|
import psycopg2
|
|
import argparse
|
|
from pathlib import Path
|
|
|
|
XLSX_PATH = Path(__file__).parent.parent / "docs" / "Sinam_Tag_all.xlsx"
|
|
DB_DSN = "host=localhost port=5432 dbname=iiot_platform user=postgres password=postgres"
|
|
|
|
parser = argparse.ArgumentParser(description='Load StatusPoint state labels into tag_metadata')
|
|
parser.add_argument('--controller', default='HC1', help='Controller ID (default: HC1)')
|
|
args = parser.parse_args()
|
|
|
|
wb = openpyxl.load_workbook(XLSX_PATH, read_only=True, data_only=True)
|
|
ws = wb['Sheet1']
|
|
rows = list(ws.iter_rows(values_only=True))
|
|
headers = rows[1]
|
|
col = {h: i for i, h in enumerate(headers) if h}
|
|
|
|
conn = psycopg2.connect(DB_DSN)
|
|
cur = conn.cursor()
|
|
|
|
inserted = 0
|
|
for row in rows[2:]:
|
|
name = str(row[col['ItemName']] or '').strip()
|
|
cls = str(row[col['Class']] or '').strip()
|
|
if cls != 'StatusPoint' or not name:
|
|
continue
|
|
|
|
# 원형(ItemName) 유지 — 소문자 변환 금지
|
|
base_tag = name
|
|
|
|
for i in range(8):
|
|
key = f'DescriptorState{i}'
|
|
if key not in col:
|
|
continue
|
|
val = row[col[key]]
|
|
if val is None or val == '':
|
|
continue
|
|
cur.execute("""
|
|
INSERT INTO hc900.tag_metadata (base_tag, attribute, value, controller_id)
|
|
VALUES (%s, %s, %s, %s)
|
|
ON CONFLICT (base_tag, attribute) DO UPDATE SET value = EXCLUDED.value, loaded_at = NOW()
|
|
""", (base_tag, f'state{i}', str(val), args.controller))
|
|
inserted += 1
|
|
|
|
conn.commit()
|
|
cur.close()
|
|
conn.close()
|
|
print(f"완료: {inserted}개 상태 레이블 저장 (controller={args.controller})")
|