Help
  • Explore Community
  • Get Started
  • Ask the Community
  • How-To & Best Practices
  • Contact Support
Notifications
Login / Register
Community
Community
Notifications
close
  • Forums
  • Knowledge Center
  • Events & Webinars
  • Ideas
  • Blogs
Help
Help
  • Explore Community
  • Get Started
  • Ask the Community
  • How-To & Best Practices
  • Contact Support
Login / Register
Sustainability
Sustainability

We Value Your Feedback!
Could you please spare a few minutes to share your thoughts on Cloud Connected vs On-Premise Services. Your feedback can help us shape the future of services.
Learn more about the survey or Click here to Launch the survey
Schneider Electric Services Innovation Team!

Sample PE Program that reads/writes files

Building Automation Knowledge Base

Schneider Electric Building Automation Knowledge Base is a self-service resource to answer all your questions about EcoStruxure Building suite, Andover Continuum, Satchwell, TAC…

cancel
Turn on suggestions
Auto-suggest helps you quickly narrow down your search results by suggesting possible matches as you type.
Showing results for 
Show  only  | Search instead for 
Did you mean: 
  • Home
  • Schneider Electric Community
  • Knowledge Center
  • Building Automation Knowledge Base
  • Sample PE Program that reads/writes files
Options
  • Bookmark
  • Subscribe
  • Email to a Friend
  • Printer Friendly Page
  • Report Inappropriate Content
Invite a Co-worker
Send a co-worker an invite to the portal.Just enter their email address and we'll connect them to register. After joining, they will belong to the same company.
You have entered an invalid email address. Please re-enter the email address.
This co-worker has already been invited to the Exchange portal. Please invite another co-worker.
Please enter email address
Send Invite Cancel
Invitation Sent
Your invitation was sent.Thanks for sharing Exchange with your co-worker.
Send New Invite Close

Related Forums

  • Intelligent Devices Forum

Previous Next
Contributors
  • DavidFisher
    DavidFisher
  • AbeMeran
    AbeMeran
  • Product_Support
    Product_Support

Invite a Colleague

Found this content useful? Share it with a Colleague!

Invite a Colleague Invite
Back to Building Automation Knowledge Base
Options
  • Bookmark
  • Subscribe
  • Email to a Friend
  • Printer Friendly Page
  • Report Inappropriate Content
0 Likes
1908 Views

Link copied. Please paste this link to share this article on your social media post.

Trying to translate this page to your language?
Select your language from the translate dropdown in the upper right. arrow
Translate to: English
  • (Français) French
  • (Deutsche) German
  • (Italiano) Italian
  • (Português) Portuguese
  • (Русский) Russian
  • (Español) Spanish

Sample PE Program that reads/writes files

Picard Product_Support
‎2018-09-11 03:06 PM

Last Updated: Administrator DavidFisher Administrator ‎2019-07-22 08:15 AM

Issue

How to read and write from/to files using PE

Product Line

Andover Continuum

Environment

  • CyberStation
  • Plain English

Cause

Site needed a CSV report of personnel accessing the building that included access event information such as time stamp, door, area, card number BUT also data such as employee number etc., a simple list view could not be used since list views can only show data from ONE table in the ContinuumDB.

Resolution

Sample CyberStation program that reads/writes from/to file and aggregate data from different tables in the ContinuumDB

IMPORTANT:
PE Program is provided as a sample proof of concept ONLY and it is not to be taken as a complete working solution.

REQUIREMENTS:
Create STRINGS ReportEventsPath and T_A_Path in the CyberStation where the program will run and set to the path to the input and output files respectively, the input file must exist, the output file will be automatically created if it doesn’t exist.

PROGRAM CODE:

'This Cyberstation program takes as an input a CSV file generated from an Access Event list
'and creates a second file with the EMPLOYEE NUMBER added.
'Program is FALL-THRU and NOT autostart
'IMPORTANT
'The Input file MUST be formatted like this...
'AccessEvent
'PersonId,TimeStamp,CardNumber,AreaId
'Root\MyPersonnel\Meran_Abe,3/31/2014 10:16:11 PM,3540,Root\MyAreas\Area1

File inputFILE, outputFILE
String 132 DATALINE, RESULT, theEMPLOYEE, empNUMBER, localSTR
Numeric CHARSREAD, CHARSWRITTEN, OK, RECORDLINE
Numeric DEBUG_FLAG

Line INITIALIZE
  DEBUG_FLAG = 0 'SET THIS TO 1 TO HAVE PROGRAM PRINT DEBUG INFO

Line OPENING
  RESULT = ""
  RECORDLINE = 0
  CHARSREAD = 0

  If OpenFile(ReportEventsPath, ReadOnly, inputFILE) = Failure then 'OPEN THE INPUT FILE TO READ FROM
    RESULT = "COULD NOT OPEN inputFILE FILE"
    Goto FAILING
  Endif

  If OpenFile(T_A_Path, WriteOnly, outputFILE) = Failure then 'OPEN THE OUTPUT FILE TO WRITE TO
    RESULT = "COULD NOT OPEN outputFILE FILE"
    Goto FAILING
  Else
    Goto COPYING
  Endif

Line COPYING
  RECORDLINE = RECORDLINE + 1
  If DEBUG_FLAG then Print "Record line = " ; RECORDLINE
  If RECORDLINE = 1 then
    OK = ReadFile(inputFILE, DATALINE, 132, CHARSREAD, "|10") 'READ FIRST LINE FROM THE INPUT FILE UP TO THE LF
  Else
    OK = ReadFile(inputFILE, DATALINE, 132, CHARSREAD, "|13") 'READ ONE LINE FROM THE INPUT FILE UP TO THE CR
  Endif
  If OK = Failure then
    RESULT = "COULD NOT READ FILE"
    Goto FAILING
  Else
    If DEBUG_FLAG then Print "Read..." ; DATALINE
    If OK = Eof then
      RESULT = "END OF FILE"
      Goto CLOSING
    Endif
  Endif

'INSERT THE EMPLOYEE NUMBER
  If RECORDLINE = 2 then empNUMBER = "EmpNumber" 'MODIFY THE HEADER WITH THE NAME OF THE FIELD(S) WE ARE ADDING
  If RECORDLINE > 2 then
    theEMPLOYEE = (left(DATALINE, search(DATALINE, ",")))
    theEMPLOYEE = (left(theEMPLOYEE, (search(theEMPLOYEE, ",") - 1))) 'FOR EACH LINE IN THE INPUT FILE GET THE PATH TO THE PERSONNEL OBJECT
    Print getname(theEMPLOYEE ; " EmpNumber") to empNUMBER 'AND GET THE EMPLOYEE NUMBER
  Endif

'WRITE THE LINE WITH THE ADDED NEW FIELD(S) TO THE OUTPUT FILE
  If RECORDLINE = 1 then
    Print DATALINE ; chr(10) to localSTR
  Else
    Print DATALINE ; "," ; empNUMBER ; chr(10) to localSTR
  Endif
  OK = WriteFile(outputFILE, localSTR, 132, CHARSWRITTEN)
  If OK = Failure then
    RESULT = "COULD NOT WRITE FILE"
    Goto FAILING
  Else
    If DEBUG_FLAG then
      Print "Wrote..." ; localSTR

    Print "CHARSWRITTEN=" ; CHARSWRITTEN
  Endif
'POINT TO THE NEXT LINE IN THE FILES
  If RECORDLINE = 1 then
    If PositionFile(inputFILE, 1, FileCurrent) = Failure then Goto CLOSING 'ADVANCE PAST THE LF
  Else
    If PositionFile(inputFILE, 2, FileCurrent) = Failure then Goto CLOSING 'ADVANCE PAST THE CR and LF
  Endif
  If PositionFile(outputFILE, 0, FileCurrent) = Failure then Goto CLOSING 'WRITE AT THE CURRENT FILE LOCATION
    Goto COPYING 'GO DO THE NEXT LINE
  Endif

Line FAILING 'SOMETHING WENT WRONG
  If DEBUG_FLAG then Print RESULT
  Goto CLOSING

Line CLOSING
'CLOSE THE FILES
  If CloseFile(inputFILE) is Failure then RESULT = "COULD NOT CLOSE FILE"
  If CloseFile(outputFILE) is Failure then RESULT = "COULD NOT CLOSE FILE"
  If DEBUG_FLAG then PEDebug = PEDebug + 1 'IF DEBUGGING INCREMENTED PEDebug MEANS NO ERRORS
  Stop

Line E 'HANDLE RUNTIME ERROR
  If DEBUG_FLAG then
    Print RESULT
    PEDebug = 666
  Endif
  CloseFile(inputFILE)
  CloseFile(outputFILE)
  Stop 

After the program runs if the input file looks like:
'AccessEvent
'PersonId,TimeStamp,CardNumber,AreaId
'Root\MyPersonnel\Meran_Abe,3/31/2014 10:16:11 PM,3540,Root\MyAreas\Area1

The output file will be:
'AccessEvent,
'PersonId,TimeStamp,CardNumber,AreaId,EmpNumber,
'Root\MyPersonnel\Meran_Abe,3/31/2014 10:16:11 PM,3540,Root\MyAreas\Area1,12345

 

Labels (1)
Labels:
  • Andover Continuum
Tags (1)
  • Find more articles tagged with:
  • 16996
Was this article helpful? Yes No
0% helpful (0/1)

Link copied. Please paste this link to share this article on your social media post.

To The Top!

Forums

  • APC UPS Data Center Backup Solutions
  • EcoStruxure IT
  • EcoStruxure Geo SCADA Expert
  • Metering & Power Quality
  • Schneider Electric Wiser

Knowledge Center

Events & webinars

Ideas

Blogs

Get Started

  • Ask the Community
  • Community Guidelines
  • Community User Guide
  • How-To & Best Practice
  • Experts Leaderboard
  • Contact Support
Brand-Logo
Subscribing is a smart move!
You can subscribe to this board after you log in or create your free account.
Forum-Icon

Create your free account or log in to subscribe to the board - and gain access to more than 10,000+ support articles along with insights from experts and peers.

Register today for FREE

Register Now

Already have an account? Login

Terms & Conditions Privacy Notice Change your Cookie Settings © 2025 Schneider Electric

This is a heading

With achievable small steps, users progress and continually feel satisfaction in task accomplishment.

Usetiful Onboarding Checklist remembers the progress of every user, allowing them to take bite-sized journeys and continue where they left.

of