[SCADA][스크립트] 보고서를 텍스트(txt) 파일로 자동 저장하는 방법 예제

안녕하세요.
CIMON 입니다.

보고서를 텍스트 파일로 자동 저장하는 예제입니다.

[이럴 때 사용하시면 됩니다]
이 예제는 시간에 따른 데이터를 txt 파일로 받아보고 싶을 때 사용하시면 됩니다.
일정관리기를 이용하여 파일 받는 시간을 정할 수도 있습니다.

[프로젝트 예제 작성 버전]
SCADA Ver 2.10(R100618), SCADA Ver 3.04(R160224)
v3.04에서 작성된 프로젝트는 하위버전에서 열리지 않습니다.
v3.04 이하의 버전을 사용하시는 분들은 v2.10에서 작성된 프로젝트를 받으셔서 프로젝트를 업그레이드를 하시기 바랍니다.

[예제 설명]
보고서를 txt파일로 받고, 매일 오전 9시에 파일을 생성하도록 설정하였습니다.

1. 읽어오고 싶은 값들을 태그로 등록합니다. 예제는 아날로그 태그 3개를 선택하였습니다.
보고서에 사용할 태그들이므로 “보고서용 데이터 생성”을 체크합니다.(보고서용 태그가 아니라면 시각에 따른 데이터가 저장되지 않습니다!)

2. 스크립트를 작성하기 전에 파일형식이 필요하므로, ReportForm.txt 파일을 만들어 프로젝트 폴더에 미리 넣어줍니다. 또는 양식파일의 위치를 양식파일이름 변수에 씁니다.
보고서가 저장될 폴더도 미리 만들어 놓습니다.
(양식파일과 파일이 생성될 경로의 폴더가 없으면 보고서가 만들어지지 않습니다.)

3. txt 보고서를 생성하는 스크립트를 작성합니다.
ReportForm.txt 파일을 만들어 프로젝트 폴더에 미리 넣어 준 경우에는 파일이름만 쓰면 됩니다.(4행) 또는 양식파일의 위치를 양식파일이름 변수에 씁니다.(6행)
ReportTimeStr() 명령어는 내부함수로 도움말을 참고하세요.
이 경우에는 -1일 : 전일 날짜, 12 : “yyyy년mm월dd일” 형식 으로 문자열로 출력합니다.

4. RunScript(“MakeReport”) 명령어를 버튼에 넣어 보고서를 출력할 수도 있고, 매일 9시에 자동으로 스크립트가 실행되도록하여 txt파일로 보고서를 출력 받을 수 있습니다.

5. CimonX를 실행하고, 버튼을 클릭하여 정상적으로 실행되는지 확인해봅니다.
예제를 작성한 8월 7일 전일인 8월 6일의 보고서용 데이터가 출력되는 것을 확인할 수 있습니다.

[적용 방법]
보고서파일명의 원하시는 시간 형식은 TimeStr(시간표시형식) 도움말을 보시고, 번호를 선택하면 됩니다.

다른 태그명을 쓰실 경우, 21행의 태그1,2,3 변경해주시고, 31~104행까지 태그명을 전부 변경해주셔야 합니다.

 

첨부 1. txtReport(v304).zip

첨부 2. txtReport(v210).zip

#텍스트(txt) 파일 저장 #일정관리기 #프로젝트예제 #SCADA샘플프로젝트 #SCADA프로젝트예제

[SCADA][기능] 윈도우 컨트롤을 사용하는 프로젝트 예제

안녕하세요.

CIMON 입니다.

 

윈도우컨트롤들을 활용하는 방법입니다.

 

[이럴 때 사용하시면 됩니다]

윈도우컨트롤 기능들이 어떻게 구현되고 동작되는지 확인해보고 싶으실 때 사용하시면 됩니다.

 

[프로젝트 예제 작성 버전]

SCADA Ver 3.04(R160224)

V3.04에서 작성된 프로젝트는 하위버전에서 열리지 않습니다.

 

[예제 설명] 

1. 체크박스와 라디오버튼을 이용한 입출력테이블 예제.

  • 각 가전제품에 해당하는 체크박스를 선택하시면 선택 시 1, 해제 시 0이 쓰이며 바로 옆의 입출력 테이블에서 해당 비트를 확인하실 수 있습니다. 라디오버튼의 약, 중, 강 세 상태가 0, 1, 2의 값으로 표현되며 이 또한 바로 옆의 입출력 테이블에서 확인하실 수 있습니다.

 

2. 에디트컨트롤을 이용한 리스트박스 예제

리스트 박스에 원하는 항목을 추가하기 위해 할 일 추가 버튼 옆의 에디트 컨트롤 창에 내용을 적고 할 일 추가 버튼을 눌러주시면 리스트박스에 삽입되어지는 것을 확인할 수 있습니다.

완료한 업무는 리스트 박스의 항목을 클릭하신 후 해당 업무 완료 버튼을 누르시면 리스트 박스 상에서 삭제됩니다.

윈도우 컨트롤 창의 현재 인덱스를 받아 그 아이템만 리스트에서 지워주는 작업을 합니다.

새로이 리스트 박스를 쓰시고 싶으시면 리스트 초기화 버튼을 눌러 리스트를 깨끗이 비울 수 있습니다.

 

3. LogDB를 이용한 리스트 컨트롤 예제

먼저 실행하기 앞서 첨부된 EXCEL_FORM.xlsx 파일을 E:\CIMON\LOG_DATA에 넣어 줍니다.

또한 도구 -> 사용자 LOG DB를 선택하신 후 좌측 트리의 WindowCtrl 밑의 USER_LOG_DB를 선택하여 줍니다. 그리고 저장 경로를 위와 마찬가지로 E:\CIMON\LOG_DATA 이 위치로 설정해줍니다.

(경로 설정은 고객님의 CIMON 폴더 저장 위치에 따라 변동해주어야 합니다. Ex) C 디스크에 CIMON 폴더이면 C:\CIMON\LOG_DATA 로 설정)

 

해당하는 생산 라인 번호와 해당 제품의 파트 번호 그리고 시리얼 넘버를 입력하신 후 항목 추가를 누르면 사용자 LOG DB 상에 입력하신 정보들이 저장됩니다.

N이 0이 출력되면 성공한 것이고 나머지 값은 실패하였음을 의미합니다.

저장된 데이터들 중 원하는 시간대에 생성된 데이터를 보고 싶을 경우 검색 시작 시간과 검색 종료 시간을 설정해 주시고 검색을 누르시면 List Control 창에 해당 데이터들이 표시될 것입니다.

Ex) 2017-08-01 00:00:00부터 2017-08-30 23:59:59 사이에 생성된 데이터를 찾고 싶을 때 2017-08-08 13:45:00 에 생성된 데이터가 LOG DB 상에 등록이 되어있으면 검색이 되어 List Control 창에 나타나게 됩니다.

GetTagVal로 각 문자열 태그에 달력 컨트롤에서 입력 받은 값을 넘기고 DbSetFindTimeStr으로 검색 시간을 설정합니다. 그리고 DbFindRun을 통해 실직적인 검색을 수행합니다. 이 때 n은 검색한 리스트의 개수를 반환합니다. wcGridCommand는 목표 List Control에 찾은 값을 출력해줍니다.

 

[적용 방법]

윈도우 컨트롤 중 체크 박스는 Bit로 라디오 버튼은 (0~8)까지 선택할 수 있는 아날로그 태그와 연결하셔서 사용하시면 됩니다.

리스트 박스와 콤보 박스는 wc함수들을 사용하여 목록에 표시, 삭제를 제어할 수 있습니다. 이 wc 함수들은 도움말 -> 연산식 및 명령식 -> 내부함수 -> 기기화면 관련 함수 에 자세한 설명과 사용법이 나오니 참조해주시기 바랍니다.

에디트 컨트롤은 태그와 연결해 실시간으로 입력 받은 데이터를 넘기는 버퍼 역할을 할 수 있습니다.

입출력 테이블은 태그의 값을 CimonX에서 실시간으로 보여주는 표 역할을 합니다.

리스트 컨트롤은 사용자 Log DB 와 연동해 많이 사용합니다. 따라서 엑셀과도 연동시켜 데이터를 효율적으로 CimonX에 표시해주는 역할을 합니다.

달력 컨트롤은 손쉽게 날짜 및 시간 정보를 입력하도록 도와줍니다.

 

#윈도우콘트롤사용예제#윈도우콘트롤사용방법#윈도우콘트롤사용샘플#윈도우콘트롤#프로젝트예제#샘플프로젝트#SCADA프로젝트예제#SCADA샘플프로젝트#SCADA윈도우콘트롤사용예제#SCADA윈도우콘트롤사용방법#SCADA윈도우콘트롤사용샘플#SCADA윈도우콘트롤

[SCADA][스크립트] 현재 시간값을 구하는 방법 예제

안녕하세요.
CIMON 입니다.

현재 시간값을 구하는 방법에 대한 예제입니다.

[이럴 때 사용하시면 됩니다]
SCADA에서 날짜나 시간을 각각 따로 구해서 사용하고 싶을 때 이용하시면 됩니다.

[프로젝트 예제 작성 버전]
SCADA Ver 2.10(R100618), SCADA Ver 3.04(R160224)
v3.04에서 작성된 프로젝트는 하위버전에서 열리지 않습니다.
v3.04 이하의 버전을 사용하시는 분들은 v2.10에서 작성된 프로젝트를 받으셔서 프로젝트를 업그레이드를 하시기 바랍니다.

[예제 설명]
현재시간값의 “년”, “월”, “일”, “시”, “분”, “초”를 각각 따로 태그값에 저장할 수 있도록 설정하였습니다.

1. 현재시간값 중 읽고 싶은 값들을 태그로 등록합니다.
예제는 현재시간의 “년, 월, 일, 시, 분, 초”의 값을 등록합니다.
그리고 읽어오는 동작을 실행시킬 디지털 태그 “측정”을 등록합니다.

2. “측정” 태그의 변화로 스크립트를 실행시키기 위해서,
“태그 동작을 지정함” 과 “태그값 변경시 태그 동작을 실행함”을 체크 합니다.
태그동작으로 스크립트를 실행합니다.

3. 읽어올 값들을 아래 페이지와 같이 작성합니다.
그림의 태그값들을 각각의 태그들과 대응하여 등록합니다.
현재시간구하기 버튼을 “측정” 태그의 토글로 설정합니다.

4. 스크립트를 작성합니다.

Sub DateSetting()

if(GetTagVal(“측정”) = 1) Then

SetTagVal “년”, Val(TimeStr(50))

SetTagVal “월”, Val(TimeStr(51))

SetTagVal “일”, Val(TimeStr(52))

SetTagVal “시”, Val(TimeStr(53))

SetTagVal “분”, Val(TimeStr(54))

SetTagVal “초”, Val(TimeStr(55))

End if

End Sub

5. 마지막으로 스크립트를 검사, 등록한 후, CimonX를 실행하여 확인합니다.
“측정”태그가 1이 될 때, 현재시간을 읽어오는 것을 확인할 수 있습니다.

 

[적용 방법]
SetTagVal “태그이름”, Val(TimeStr(번호)) 명령어를 이용하고, RunScript(“스크립트”)를 사용하시면 언제든지 현재시간값 중 원하는 내용을 가져올 수 있습니다.
TimStr() 이 현재시간값에서 가져올 수 있는 형식이 66(0 ~ 65)가지나 되므로, 도움말에서 확인하세요.

 

첨부 1. GetTime(v2_10).zip     (SCADA Ver 2.10)
첨부 2. GetTime(v3_04).zip     (SCADA Ver 3.04)

#시간#현재시간#현재시간값#시간구하기#시간값구하기#예제#샘플프로젝트#SCADA 프로젝트

[SCADA][스크립트] CimonX에서 Excel을 이용하여 데이터 읽고 쓰기

 

안녕하세요.

CIMON 입니다.

Excel로  SCADA 태그의 값을 쓰거나 Excel로부터 SCADA의 태그로 셀 값을 읽어오는 Sample입니다.

 

[ 이럴 사용하시면 됩니다]

이 예제는 엑셀과 스카다를 연동시켜 각 셀에 대응해 데이터를 쓰기/읽기하시고 싶을 때 사용하시면 됩니다.

 

[ 프로젝트 예제 작성 버전 ]

SCADA Ver 3.04(R160224)

 

 [ 예제 설명 ]

1. 엑셀로 태그값을 쓰는 예제입니다. D0001~D0004까지 각각 엑셀 Sheet1의 셀 A1~D1에 해당하며 Excel Write 버튼을 누르면 각 태그에 설정한 값이 해당 파일 생성 날짜 (ex 20170806.xlsx) 파일로 프로젝트 폴더에 생성됩니다.

2. Excel Write를 누르면 실행되는 WriteExcel 스크립트입니다.

각 태그의 값을 읽어와 해당 Range(이 예제에서는 셀)에 태그에 저장된 데이터를 써줍니다.

3. 위의 스크립트가 실행이 되면 아래와 같이 (201700806.xlsx) 파일에 각각 D0001, D0002, D0003, D0004에 해당하는 태그 값들이 쓰여집니다.

4. 이번에는 엑셀에 저장된 데이터를 읽어오는 예제를 설명 드리겠습니다. 아래와 같이 달력 컨트롤을 이용하여 불러올 날짜를 입력하여 그 날짜에 해당하는 엑셀 파일을 읽어 들입니다. 설정한 해당 날짜에 맞는 Excel 파일이 있으면 A1~D1에 해당되는 셀 값을 읽어 오른쪽 네 개의 태그에 표현해줍니다.

 

5. 다음은 ExcelRead를 클릭하면 실행되는 ReadExcel 스크립트입니다. WriteExcel에서와 반대로, GetTagVal가 아닌 엑셀의 셀값을 그대로 SetTagVal로 태그에 입력해주는 것을 확인할 수 있습니다.

 

[적용 방법]

읽어오거나 쓰는 데이터/셀의 개수를 추가시키고 싶으시다면

Sheet1.Range(“E1”).Value = GetTagVal(“D0005”) 혹은

SetTagVal “READ5”, Sheet1.Range(“E1).Value

과 같이 추가시켜주시면 됩니다.

 

#EXCEL읽기쓰기#EXCELREADWRITE#EXCEL데이터쓰기#EXCEL데이터읽기#EXCEL데이터샘플#EXCEL#프로젝트예제#샘플프로젝트#SCADA프로젝트예제#SCADA샘플프로젝트#SCADAEXCEL사용예제#SCADAEXCEL사용방법#SCADAEXCEL사용샘플#SCADAEXCEL

 

 

 

 

[SCADA][스크립트] 태그값을 텍스트(txt) 파일에 저장하고 엑셀에 저장하는 방법 예제

안녕하세요.
CIMON 입니다.

아날로그 태그에 있는 값들을 텍스트(txt) 파일에 저장하고 엑셀 파일에 저장하는 방법에 대한 프로젝트 예제 및 사용법 설명 드립니다.

[이럴 때 사용하시면 됩니다]
태그값들을 임의로 txt파일 또는 엑셀파일로 출력하고 싶을 때 사용하시면 됩니다.

[프로젝트 예제 작성 버전]
SCADA Ver 3.04(R160224)
v3.04에서 작성된 프로젝트는 하위버전에서 열리지 않습니다.

[예제 설명]
스크립트를 등록하고 실행하여, 데이터베이스의 아날로그 태그값들을 txt파일에 저장할 수 있습니다.
txt 파일에 저장된 내용을 똑같이 엑셀 파일에 저장할 수 있습니다.

1. 데이터베이스에 DATA그룹을 만들고 20개의 WEIGHT## 아날로그태그를 등록합니다.

 

2. 사용할 텍스트 파일 양식과 엑셀 파일 양식을 만듭니다. 스크립트 작성시 해당파일의 경로를 확인하시기 바랍니다.

 

3. txt파일 생성은 응용프로그램이 따로 필요하지 않지만, 엑셀에 저장하기 위해서는 엑셀응용프로그램을 사용해야 합니다. 엑셀에 연결하는 스크립트를 등록합니다.

 

4. txt 파일에 태그값들을 저장하는 스크립트를 등록, 작성합니다.

 

5. txt파일에서 엑셀파일로 데이터를 옮겨 저장하는 스크립트를 등록, 작성합니다.

 

6. CimonX에서 4번의 txt파일 생성 스크립트와 5번의 엑셀파일 생성 스크립트를 순서대로 실행합니다.

 

7. 파일이 생성되고 저장된 것을 확인 할 수 있습니다.

[적용 방법]
형식들을 잘 지켜주세요. 파일이름변수는 정확히 파일저장경로를 표현해야 합니다. 태그값은 CStr(GetTagVal(“태그명” & format(i, “00”)) 으로 표현되어,
aaa$에 tab 간격으로 표현되고 있습니다. i는 태그의 뒤에 붙는 숫자를 표현하고 있으니, 원하는 태그 갯수를 맞춰서 태그명+숫자로 데이터베이스에 태그를 등록하세요.
현재 예제는 엑셀에서 Z열까지 밖에 표현되지 않아 i는 최대 23까지 쓸 수 있습니다. Ex) For i = 0 to 23(Maximum)

 

첨부 1. WriteTXTandEXCEL.zip (SCADA v3.04)

 

#텍스트값주기#텍스트값엑셀에쓰기#엑셀에쓰는샘플#엑셀에쓰는예제#프로젝트예제#SCADA프로젝트예제#SCADA프로젝트

P15RBW의 19인치 Rack 치수 파일

안녕하세요

연구개발팀의 김은호입니다.

P15RBW의 외형 19인치 RACK의 치수파일입니다

 

컷팅사이즈에 대해서 자세하게 나와 있으니

참고하시기 바랍니다.

 

감사합니다.

#PPC드라이버#PPC외형치수#PPC컷사이즈#P15RBW외형치수#19인치외형치수#19인치RACK치수