<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="de">
	<id>https://wiki-de.moshellshocker.dns64.de/index.php?action=history&amp;feed=atom&amp;title=Strukturierter_Text</id>
	<title>Strukturierter Text - Versionsgeschichte</title>
	<link rel="self" type="application/atom+xml" href="https://wiki-de.moshellshocker.dns64.de/index.php?action=history&amp;feed=atom&amp;title=Strukturierter_Text"/>
	<link rel="alternate" type="text/html" href="https://wiki-de.moshellshocker.dns64.de/index.php?title=Strukturierter_Text&amp;action=history"/>
	<updated>2026-06-03T11:26:18Z</updated>
	<subtitle>Versionsgeschichte dieser Seite in Wikipedia (Deutsch) – Lokale Kopie</subtitle>
	<generator>MediaWiki 1.43.8</generator>
	<entry>
		<id>https://wiki-de.moshellshocker.dns64.de/index.php?title=Strukturierter_Text&amp;diff=230400&amp;oldid=prev</id>
		<title>imported&gt;Raugeier: weblinkfix</title>
		<link rel="alternate" type="text/html" href="https://wiki-de.moshellshocker.dns64.de/index.php?title=Strukturierter_Text&amp;diff=230400&amp;oldid=prev"/>
		<updated>2026-03-03T17:47:17Z</updated>

		<summary type="html">&lt;p&gt;weblinkfix&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Neue Seite&lt;/b&gt;&lt;/p&gt;&lt;div&gt;Der &amp;#039;&amp;#039;&amp;#039;strukturierte Text&amp;#039;&amp;#039;&amp;#039; (engl. &amp;#039;&amp;#039;&amp;#039;Structured Text&amp;#039;&amp;#039;&amp;#039;, Abkürzung: &amp;#039;&amp;#039;&amp;#039;ST&amp;#039;&amp;#039;&amp;#039;; in Siemens S7 auch engl. &amp;#039;&amp;#039;&amp;#039;Structured Control Language&amp;#039;&amp;#039;&amp;#039;, Abkürzung &amp;#039;&amp;#039;&amp;#039;SCL&amp;#039;&amp;#039;&amp;#039;) ist eine [[Programmiersprache]] für [[Speicherprogrammierbare Steuerung]]en (SPS).&lt;br /&gt;
Die Norm [[EN 61131]]-3 legt neben anderen auch den Sprachumfang von ST fest. Dabei ist die Syntax der Sprachelemente ähnlich denen der [[Höhere Programmiersprache|Hochsprache]] [[Pascal (Programmiersprache)|Pascal]] und es wird wie bei allen Sprachen der EN 61131-3 bei [[Schlüsselwort (Programmierung)|Schlüsselwörtern]] keine Unterscheidung zwischen Groß- und Kleinschreibung gemacht (Case Insensitive).&lt;br /&gt;
&lt;br /&gt;
ST bietet mehr Strukturierungsmöglichkeiten als [[Anweisungsliste|AWL]] und löst diese daher immer mehr ab. Komplexe Algorithmen und mathematische Funktionen lassen sich in ST übersichtlicher und schneller programmieren.&amp;lt;ref name=&amp;quot;:0&amp;quot;&amp;gt;{{Internetquelle |autor=Ulrich Becker |url=https://web.archive.org/web/20260303174602/https://docplayer.org/storage/33/16440628/1772563503/sVM09fmXk5-sIloRnLlGqw/16440628.pdf |titel=Einführung in die Programmiersprache Strukturierter Text (ST) |format=PDF |abruf=2026-03-03}}&amp;lt;/ref&amp;gt;&lt;br /&gt;
&lt;br /&gt;
== Sprachelemente Strukturierter Text ==&lt;br /&gt;
=== Zuweisung ===&lt;br /&gt;
Als Zuweisungsoperator wird im Strukturierten Text „:=“ verwendet.&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;text&amp;quot;&amp;gt;&lt;br /&gt;
 Wert := Wert1 + Wert2;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
Dem Operanden auf der linken Seite, wird der Wert des Ausdruckes auf der rechten Seite zugewiesen. Der Zuweisungsoperator ist nicht mit dem [[Vergleichsoperator]] „=“ zu verwechseln. Jede Anweisung wird mit einem Semikolon abgeschlossen.&lt;br /&gt;
=== IF-Statement ===&lt;br /&gt;
Mit IF-Anweisungen lassen sich Anweisungen programmieren, die von Bedingungen abhängig sind. Die Bedingungen werden der Reihe nach geprüft. Ist Bedingung1 der IF-Anweisung wahr, wird die Bedingung des ELSIF-Zweiges nicht mehr überprüft.&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;text&amp;quot;&amp;gt;&lt;br /&gt;
IF Bedingung1 THEN&lt;br /&gt;
  Anweisung1;&lt;br /&gt;
ELSIF Bedingung2 THEN&lt;br /&gt;
  Anweisung2;&lt;br /&gt;
ELSE&lt;br /&gt;
  Anweisung3;&lt;br /&gt;
END_IF;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
=== CASE-Statement ===&lt;br /&gt;
Mit einem CASE-Statement lassen sich mehrere bedingte Anweisungen programmieren, die alle von der gleichen Bedingungsvariable abhängig sind.&amp;lt;ref name=&amp;quot;:1&amp;quot;&amp;gt;{{Internetquelle |url=https://www.wago.com/wagoweb/documentation/759/ger_manu/333/m07590333_00000000_1de.pdf |titel=Handbuch für SPS Programmierung mit CoDeSys 2.3 |abruf=2017-06-21 |format=PDF}}&amp;lt;/ref&amp;gt; Nimmt die Bedingungsvariable keinen der angegebenen Werte an, wird der ELSE-Zweig ausgeführt.&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;text&amp;quot;&amp;gt;&lt;br /&gt;
  CASE Bedingungsvariable OF&lt;br /&gt;
    1 : Anweisung1;&lt;br /&gt;
    2 : Anweisung2;&lt;br /&gt;
    3 : Anweisung3;&lt;br /&gt;
    ELSE Anweisung4;&lt;br /&gt;
  END_CASE;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
=== FOR-Statement ===&lt;br /&gt;
Mit Hilfe von For-Schleifen lassen sich wiederholende Vorgänge programmieren.&amp;lt;ref name=&amp;quot;:0&amp;quot; /&amp;gt; Dabei wird die Anweisung in der Schleife so oft wiederholt, bis die Variable i den Endwert überschreitet. Bei jedem Schleifendurchlauf wird die Variable um eine Schrittweite erhöht.&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;text&amp;quot;&amp;gt;&lt;br /&gt;
FOR i := 0 TO 499 BY 1 DO&lt;br /&gt;
  Zahl := Zahl +1;&lt;br /&gt;
  D[i] := Zahl;&lt;br /&gt;
END_FOR;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
Im Codebeispiel wird ein Array mit 500 Plätzen beschrieben.&lt;br /&gt;
&lt;br /&gt;
=== WHILE-Statement ===&lt;br /&gt;
Mit WHILE Schleifen lassen sich Vorgänge programmieren, die oft wiederholt werden müssen. Die Anweisung in der Schleife wird wiederholt, solange die Bedingung erfüllt ist. Ist die Anzahl der Schleifendurchläufe bekannt, wird meistens eine FOR Schleife verwendet. Bei einer WHILE Schleife sollte man beachten, dass die Bedingung nicht dauerhaft erfüllt ist. Ansonsten entstehen Endlosschleifen.&amp;lt;ref name=&amp;quot;:0&amp;quot; /&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;text&amp;quot;&amp;gt;&lt;br /&gt;
  WHILE Bedingung DO&lt;br /&gt;
    Anweisung;&lt;br /&gt;
  END_WHILE;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
=== REPEAT-Statement ===&lt;br /&gt;
Das REPEAT Statement ist einem WHILE Statement sehr ähnlich. Der Unterschied zu einer WHILE Schleife liegt darin, dass die Abbruchbedingung erst nach dem Ausführen der Schleife überprüft wird (C++: do{}/while()).&amp;lt;ref name=&amp;quot;:1&amp;quot; /&amp;gt;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;text&amp;quot;&amp;gt;&lt;br /&gt;
  REPEAT&lt;br /&gt;
    Anweisung;&lt;br /&gt;
  UNTIL Bedingung&lt;br /&gt;
  END_REPEAT;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
Im vorliegenden Beispiel wird die Anweisung so lange ausgeführt, bis die Bedingung erfüllt ist. Die Anweisung wird mindestens ein Mal ausgeführt, da die Abbruchbedingung erst nach dem Durchlaufen der Anweisung abgefragt wird.&lt;br /&gt;
&lt;br /&gt;
=== EXIT Anweisung ===&lt;br /&gt;
Eine FOR, WHILE, oder REPEAT Schleife kann vorzeitig mit einer EXIT Anweisung verlassen werden.&lt;br /&gt;
&lt;br /&gt;
=== Pointer ===&lt;br /&gt;
[[Zeiger (Informatik)|Pointer]] enthalten die Adressen des Speicherplatzes von Variablen. Die Adresse einer Variable wird durch den Adressoperator ADR ermittelt. Die Dereferenzierung eines Pointers erfolgt mit Hilfe des Inhaltsoperators „^“.&amp;lt;ref&amp;gt;{{Internetquelle |url=https://infosys.beckhoff.de/index.php?content=../content/1031/TcPlcControl/HTML/TcPlcCtrl_POINTER.htm&amp;amp;id= |titel=Beckhoff Information System - German |abruf=2017-05-22}}&amp;lt;/ref&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;text&amp;quot;&amp;gt;&lt;br /&gt;
  pAdresse  := ADR(Wert1);&lt;br /&gt;
  Wert2     := pAdresse^;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
In diesem Beispiel wird der Variable Wert2 der Inhalt der Variable Wert1 mit Hilfe eines Pointers zugewiesen. Die Zuweisung erfolgt über die Dereferenzierung des Pointers pAdresse.&lt;br /&gt;
&lt;br /&gt;
== Literatur ==&lt;br /&gt;
* Dr. Ulrich Becker: &amp;#039;&amp;#039;Grundlagen der Automatisierungstechnik, Kapitel 13: Einführung in die Programmiersprache Strukturierter Text (ST)&amp;#039;&amp;#039;&lt;br /&gt;
* Karl Schmitt: &amp;#039;&amp;#039;SPS-Programmierung mit ST: nach IEC 6113 mit CoDeSys und mit Hinweisen zu STEP 7 im TIA-Portal&amp;#039;&amp;#039;. Vogel Business Media 2015, ISBN 978-3-8343-3369-8&lt;br /&gt;
* Ulrich Kanngießer: &amp;#039;&amp;#039;Programmierung mit Strukturierter Text: Steuerungs-Funktionsbausteine mit ST oder SCL einfach und schnell erstellen. Für Ein- und AWL-Umsteiger&amp;#039;&amp;#039;. VDE VERLAG 2014, ISBN 978-3-8007-3463-4&lt;br /&gt;
* Heinrich Lepers: &amp;#039;&amp;#039;SPS-Programmierung nach IEC 61131-3&amp;#039;&amp;#039;. 4. Auflage. Franzis Verlag. Haar 2011, ISBN 978-3-645-65092-2&lt;br /&gt;
* 3S – Smart Software Solutions GmbH: Handbuch für SPS Programmierung mit CoDeSys 2.3: https://www.wago.com/wagoweb/documentation/759/ger_manu/333/m07590333_00000000_1de.pdf (abgerufen am 29. April 2017)&lt;br /&gt;
* Tom Mejer Antonsen (2018), &amp;quot;PLC Controls with Structured Text (ST): IEC 61131-3 and best practice ST programming” ISBN 978-87-430-0241-3, ISBN 978-87-430-0242-0, ISBN 978-87-430-0637-4 (E-Book)&lt;br /&gt;
&lt;br /&gt;
== Einzelnachweise ==&lt;br /&gt;
&amp;lt;references /&amp;gt;&lt;br /&gt;
&lt;br /&gt;
[[Kategorie:Speicherprogrammierbare Steuerung]]&lt;br /&gt;
[[Kategorie:Programmiersprache]]&lt;/div&gt;</summary>
		<author><name>imported&gt;Raugeier</name></author>
	</entry>
</feed>