Handledningar

Hur man automatiserar TIA Portal med Openness API

Den definitiva guiden för att omvandla ditt Siemens ingenjörsarbetsflöde till en modern DevOps-pipeline.

T
T-IA Connect Team
15 min läsning
Uppdaterad 10 mar 2026

Varför automatisering är oundviklig

Manuell ingenjörskonst i TIA Portal är långsam och felbenägen. Högerklicka, skapa block, kopiera och klistra in kod... Dessa repetitiva uppgifter måste försvinna. Tack vare Openness API (och dess T-IA Connect REST-wrapper) kan du styra TIA Portal som vilken modern programvara som helst.

Förkunskaper

  • TIA Portal V16, V17, V18, V19 eller V21 installerat
  • En T-IA Connect-licens (eller Freemium-plan)
  • PowerShell eller Python installerat på din maskin

Steg 1: Starta REST API

Istället för att starta TIA Portal manuellt startar vi T-IA Connect-servern som fungerar som en gateway. Öppna din terminal och kör:

PowerShell
./TiaPortalApi.App.exe --headless

Steg 2: Health Check

Först, låt oss verifiera att API:et körs och vilka TIA Portal-versioner som finns tillgängliga.

curl
curl http://localhost:9000/api/health

curl http://localhost:9000/api/health/versions
Response
{
  "status": "healthy",
  "tiaPortalConnected": true,
  "uptime": "00:01:23"
}

{
  "installedVersions": ["V17", "V18", "V19"]
}

Steg 3: Skapa ett Projekt

Inga fler 'Arkiv > Nytt'-menyer. Låt oss skicka en POST-begäran för att skapa ett tomt projekt.

curl — POST /api/projects/actions/create
curl -X POST http://localhost:9000/api/projects/actions/create \
  -H "Content-Type: application/json" \
  -d '{
    "name": "MyAutomatedProject",
    "path": "C:\\TIA_Projects",
    "version": "V19"
  }'
Response
{
  "name": "MyAutomatedProject",
  "path": "C:\\TIA_Projects\\MyAutomatedProject",
  "version": "V19",
  "created": true
}

Steg 4: Lägg till PLC & Skapa FB

Sök efter en CPU i hårdvarukatalogen, lägg till den i projektet och skapa ett Funktionsblock med SCL-kod — allt med några API-anrop.

curl — Search catalog + Add device
# Search the hardware catalog
curl -X POST http://localhost:9000/api/catalog/actions/search \
  -H "Content-Type: application/json" \
  -d '{ "searchPattern": "CPU 1511" }'

# Add the device to the project
curl -X POST http://localhost:9000/api/projects/devices/actions/add \
  -H "Content-Type: application/json" \
  -d '{
    "name": "PLC_1",
    "typeId": "<typeId from search>",
    "deviceName": "CPU 1511C-1 PN"
  }'

# Create a Function Block
curl -X POST http://localhost:9000/api/devices/PLC_1/blocks \
  -H "Content-Type: application/json" \
  -d '{
    "name": "FB_MotorControl",
    "type": "FB",
    "programmingLanguage": "SCL"
  }'

# Add SCL code to the block
curl -X POST http://localhost:9000/api/devices/PLC_1/blocks/FB_MotorControl/networks \
  -H "Content-Type: application/json" \
  -d '{
    "title": "Motor control logic",
    "code": "#Running := #Start AND NOT #Stop;\nIF #Running THEN\n  #Speed := #SpeedSetpoint;\nEND_IF;"
  }'
Response
// Block creation response
{
  "name": "FB_MotorControl",
  "type": "FB",
  "programmingLanguage": "SCL",
  "number": 1
}

// Network added
{
  "networkId": 1,
  "title": "Motor control logic",
  "created": true
}

Steg 5: Skapa Taggar

Importera PLC-taggar (ingångar, utgångar, minne) i bulk med ett enda API-anrop.

curl — POST /api/devices/PLC_1/tags/actions/import
curl -X POST http://localhost:9000/api/devices/PLC_1/tags/actions/import \
  -H "Content-Type: application/json" \
  -d '{
    "tagTable": "Motors",
    "tags": [
      { "name": "Motor1_Start",   "dataType": "Bool", "address": "%I0.0" },
      { "name": "Motor1_Stop",    "dataType": "Bool", "address": "%I0.1" },
      { "name": "Motor1_Running", "dataType": "Bool", "address": "%Q0.0" },
      { "name": "Motor1_Speed",   "dataType": "Real", "address": "%QD4"  },
      { "name": "Motor1_Fault",   "dataType": "Bool", "address": "%Q0.1" }
    ]
  }'
Response
{
  "tagTable": "Motors",
  "importedCount": 5,
  "tags": [
    { "name": "Motor1_Start",   "dataType": "Bool", "address": "%I0.0" },
    { "name": "Motor1_Stop",    "dataType": "Bool", "address": "%I0.1" },
    { "name": "Motor1_Running", "dataType": "Bool", "address": "%Q0.0" },
    { "name": "Motor1_Speed",   "dataType": "Real", "address": "%QD4"  },
    { "name": "Motor1_Fault",   "dataType": "Bool", "address": "%Q0.1" }
  ]
}

Steg 6: Kompilera Projektet

Starta en kompilering och följ förloppet via Jobs API. Kompileringen körs asynkront.

curl — Compile + Poll job
# Start compilation
curl -X POST http://localhost:9000/api/devices/PLC_1/actions/compile

# Poll the job status (replace <jobId>)
curl http://localhost:9000/api/jobs/<jobId>
Response
// Compilation started
{ "jobId": "c7f3a1b2-...", "status": "running" }

// Job completed
{
  "jobId": "c7f3a1b2-...",
  "status": "completed",
  "errors": [],
  "warnings": 2
}

Steg 7: Exportera till XML

Exportera dina block till SimaticML (XML) format för versionshantering med Git.

curl — POST /api/devices/PLC_1/blocks/actions/export
curl -X POST http://localhost:9000/api/devices/PLC_1/blocks/actions/export \
  -H "Content-Type: application/json" \
  -d '{
    "blocks": ["FB_MotorControl"],
    "exportPath": "C:\\TIA_Projects\\Export"
  }'
Response
{
  "exportedCount": 1,
  "exportPath": "C:\\TIA_Projects\\Export",
  "files": ["FB_MotorControl.xml"]
}

Steg 8: Spara och Stäng

Spara projektet och stäng det ordentligt. TIA Portal-instansen är fri för nästa automatiserade körning.

curl — Save & Close
curl -X POST http://localhost:9000/api/projects/actions/save

curl -X POST http://localhost:9000/api/projects/actions/close
Response
{ "saved": true }

{ "closed": true }

Vad händer härnäst?

Du har precis automatiserat 90% av de manuella projektskapande uppgifterna. Du kan nu integrera detta skript i din CI/CD-pipeline (Jenkins, GitLab CI) för att validera din kod vid varje commit.

Ladda ner de kompletta skripten för denna tutorial och prova dem med vår gratis Freemium-plan.