Post by eschwellinger on Lizenz ausversehen für WORKSTATION statt für GERÄT installiert - wie kann ich diese verschieben?
CODESYS Forge
talk
(Post)
nö...schreib doch einfach dem Support da wird für bei sowas geholfen." Meine Frage" im Store ist auch für sowas.
Last updated: 2024-10-19
Post by jepl-1012 on configuration error for SM_Drive_GenericDSP402
CODESYS Forge
talk
(Post)
Hi All, I Am using Delta AX8 Controller And IndrDrive HCS01 With Ethercat COE (Cia402 Profile) .Communication has done properly but while i made MC_Power block on its not get enable. what is the issue can any one help me
Last updated: 2024-10-21
Post by banialuk on Modbus TCP Server
CODESYS Forge
talk
(Post)
I created Modbus Server TCP, but when I try started i have a error "TCP socet error" "Error on open/close/read/write TCP socket."
Last updated: 2024-10-21
Post by sebastianrapi on Bibliothek: floatingpointutils
CODESYS Forge
talk
(Post)
danke für deine Antwort. Ich habe nun einfach ein Projekt erstellt inklusive der Bib "FloatingPointUtils, 3.5.17.0 (System)" Beim Auswählen einer Funktion, z.B. HexStrToReal kommt die besagt Fehlermeldung...
Last updated: 2024-10-22
Post by timvh on TrueType font problem
CODESYS Forge
talk
(Post)
We have also used the Roboto font without any problems, but possibly your company modified it a little bit? Maybe you can try the original ones from Google: https://fonts.google.com/specimen/Roboto
Last updated: 2024-10-23
Post by winki on Modbus TCP & RTU with Control for Linux SL
CODESYS Forge
talk
(Post)
I do not have error anymore using nic with eth0 value. But my network it still 172.17.0.3 like the first picture.
Last updated: 2024-10-23
Post by yoeri on Refresh visulization realtime
CODESYS Forge
talk
(Post)
Works like a charm. I have added a counter which ups the Bitmap version by 1 each second and it refreshes nicely. Thank you Tim!
Last updated: 2024-10-25
Post by ton on Beckhoff EK series cannot detect but BK1120 detect
CODESYS Forge
talk
(Post)
Hi, I guess you don't have the right xml file. Download Beckhoff_EtherCAT_BKxxx_MDP.zip from https://download.beckhoff.com/download/configuration-files/io/ethercat/xml-device-description and install these in Device Repository.
Last updated: 2024-11-01
Post by eschwellinger on Persistence Manager: Config File not found?
CODESYS Forge
talk
(Post)
..strange just switching of this device without graceful Linux OS shutdown? Reset orgin on the device tree and a new download of the application will bring it up and running again but sure then the persistent data are for sure lost.
Last updated: 2024-11-02
Post by markushunter on loading delay with the option "check client animations and overlay of native elements"
CODESYS Forge
talk
(Post)
Hey etiennenneu, I have the same problem with our prototype cell application. Do you have found a workaround for it? Best regards, Markus
Last updated: 2024-11-04
Post by sebastianrapi on Bibliothek: floatingpointutils
CODESYS Forge
talk
(Post)
Hi, ich wollte mal freundlich nachfragen, ob es eine Lösung zu dem Problem mit der Bib gibt... Vielleicht weiß ja jemand, was zu tun oder zu beachten ist. Oder kann mir jemand sagen, ob die Bib bei ihm verwendbar ist?!? Danke
Last updated: 2024-11-05
Post by jemall on Kontextmenü plötzlich kleiner
CODESYS Forge
talk
(Post)
Hallo, seit dieser Woche fehlen mir im Kontextmenü (Rechtsklick auf ein Netzwerk) mehrere Punkte. Statt Netzwerk auskommentieren oder Eingänge negieren zu können, gibt es nur noch kopieren/einfügen/ausschneiden. Über die Icons im Menü oben geht alles noch ganz normal.
Last updated: 2024-11-05
Post by timvh on Case Function - Multiple Conditions, Is it possible?
CODESYS Forge
talk
(Post)
This is not possible. Possible solution could be: CASE var1 OF 10: CASE var2 OF 10:; 20:; END_CASE 20: CASE var2 OF 10:; 20:; END_CASE ELSE ; END_CASE
Last updated: 2024-11-05
Post by pistola on Case Function - Multiple Conditions, Is it possible?
CODESYS Forge
talk
(Post)
Thanks for the information, I ended up just making a long if else statement as each variable had 3 possible options, I figured at least this way it would still work.
Last updated: 2024-11-05
Post by s1ack on Undertanding Application Based Licenses
CODESYS Forge
talk
(Post)
Can anyone confirm my thinking here that this project will require Control Standard M because of the I/O channel count under the fieldbus?
Last updated: 2024-11-08
Post by ellocco on Kann mich nicht am Gerät anmelden
CODESYS Forge
talk
(Post)
CODESYSV3.5 SP20: Habe gerade wieder Ärger mit dem virtuellen Gerät (DEVICE) CODESYSControlWinV3x64 und stelle fest, dass der Ordner jetzt versteckt irgendwo anders liegt ... Auch die Datei .GroupDatabase.csv kann ich nicht mehr finden.
Last updated: 5 days ago
Post by francesco86 on Script python for write in a file Project information
CODESYS Forge
talk
(Post)
Dear all, My python script can read a Codesys project and save in file the different POU, but the problem is that I don't able to read the project info from the obj list. Following of this message there is my python script. Can you help my? Best regards Francesco # encoding:utf-8 # We enable the new python 3 print syntax from __future__ import print_function import os import shutil import time import sys from datetime import datetime print("--- Saving files in the project: ---") print("sys.argv: ", len(sys.argv), " elements:") for arg in sys.argv: print(" - ", arg) if (len(sys.argv)>1): folderExportName = sys.argv[1] print(" folderExportName: ", folderExportName) exportPath = sys.argv[2]+ sys.argv[3]+ "\\"+ sys.argv[1] print(" File path: ", exportPath) # git has_repo=False #save_folder=r'E:\Tmp\ControlPlugins\ControlPlugins\Export' save_folder = exportPath if not os.path.exists(save_folder): os.makedirs(save_folder) else: a=os.listdir(save_folder) for f in a: if not f.startswith("."): sub_path= os.path.join(save_folder,f) if os.path.isdir(sub_path): shutil.rmtree(sub_path) else: os.remove(sub_path) elif f==".git": has_repo=True info={} type_dist={ '792f2eb6-721e-4e64-ba20-bc98351056db':'pm', #property method '2db5746d-d284-4425-9f7f-2663a34b0ebc':'dut', #dut 'adb5cb65-8e1d-4a00-b70a-375ea27582f3':'lib', #lib manager 'f89f7675-27f1-46b3-8abb-b7da8e774ffd':'m', #method no ret '8ac092e5-3128-4e26-9e7e-11016c6684f2':'act', #action '6f9dac99-8de1-4efc-8465-68ac443b7d08':'pou', #pou '6654496c-404d-479a-aad2-8551054e5f1e':'itf', #interface '738bea1e-99bb-4f04-90bb-a7a567e74e3a':'', #folder 'ffbfa93a-b94d-45fc-a329-229860183b1d':'gvl', #global var '5a3b8626-d3e9-4f37-98b5-66420063d91e':'prop', #property '2bef0454-1bd3-412a-ac2c-af0f31dbc40f':'tl', #textlist '63784cbb-9ba0-45e6-9d69-babf3f040511':'gtl', #global textlist '225bfe47-7336-4dbc-9419-4105a7c831fa':'dev', #device 'ae1de277-a207-4a28-9efb-456c06bd52f3':'tc', #task configuration 'f8a58466-d7f6-439f-bbb8-d4600e41d099':'m', #method with ret '261bd6e6-249c-4232-bb6f-84c2fbeef430':'gvl', #gvl_Persistent '98a2708a-9b18-4f31-82ed-a1465b24fa2d':'task', #task '085afe48-c5d8-4ea5-ab0d-b35701fa6009':'progInfo'#project information }; def save(text,path,name,tp): if not tp: tp='' else: tp='.'+tp+'.txt' with open(os.path.join(path,name+tp),'w') as f: f.write(text.encode('utf-8')) def print_tree(treeobj, depth, path): global info #record current Path curpath=path isfolder=False t='' #text tp='' #type # get object name name = treeobj.get_name(False) id = treeobj.type.ToString() if id in type_dist: tp = type_dist[treeobj.type.ToString()] #Print all type of objects #print("--Name: ", tp) else: info[id]=name if treeobj.is_device: deviceid = treeobj.get_device_identification() t = 'type='+str(deviceid.type) +'\nid=' +str(deviceid.id) + '\nver='+ str(deviceid.version) if tp == "progInfo": print("-- There is prog info, ", tp) print("-- It has textual declaration: , ", treeobj.has_textual_declaration) print("-- It has textual implementation: , ", treeobj.has_textual_implementation) print("-- It is folder: , ", treeobj.is_folder) print("-- It is children: , ", treeobj.get_children(False)) print("-- It is children len: , ", len(treeobj.get_children(False))) print("-- It is progInfo type: , ", type(treeobj.ScriptProject)) #for child in treeobj.get_children(False): # print_tree(child, depth+1,curpath) try: if treeobj.is_folder : #system.ui.prompt('folder:'+u, PromptChoice.YesNo, PromptResult.Yes) isfolder=true pass except: pass if treeobj.has_textual_declaration : t=t+'(*#-#-#-#-#-#-#-#-#-#---Declaration---#-#-#-#-#-#-#-#-#-#-#-#-#*)\r\n' a=treeobj.textual_declaration t=t+a.text if treeobj.has_textual_implementation: t=t+'(*#-#-#-#-#-#-#-#-#-#---Implementation---#-#-#-#-#-#-#-#-#-#-#-#-#*)\r\n' a=treeobj.textual_implementation t=t+a.text if treeobj.has_textual_declaration and not treeobj.has_textual_implementation: t=t+'(*#-#-#-#-#-#-#-#-#-#---NOT Implementation visible---#-#-#-#-#-#-#-#-#-#-#-#-#*)\r\n' if treeobj.is_task : exports=[treeobj] projects.primary.export_native(exports,os.path.join(curpath,name+'.task')) if treeobj.is_libman: exports=[treeobj] projects.primary.export_native(exports,os.path.join(curpath,name+'.lib')) if treeobj.is_textlist: treeobj.export(os.path.join(curpath,name+'.tl')) children = treeobj.get_children(False) if children or isfolder: if tp: curpath=os.path.join(curpath,name+'.'+tp) else: curpath=os.path.join(curpath,name) if not os.path.exists(curpath): os.makedirs(curpath) if t: save(t,curpath,name,tp) for child in treeobj.get_children(False): print_tree(child, depth+1,curpath) for obj in projects.primary.get_children(): print_tree(obj,0,save_folder) with open(os.path.join(save_folder,'ExportInfo.txt'),'w') as f: now = datetime.now() infTimeExecution = now.strftime("%Y-%m-%d %H:%M:%S") f.write("Export date and time: "+infTimeExecution + "\r\n" + str(info)) print("--- Script finished. ---") #system.ui.info('save ok') projects.primary.close()
Last updated: 2024-04-30
Post by francesco86 on Script python for write in a file Project information
CODESYS Forge
talk
(Post)
Dear all, My python script can read a Codesys project and save in file the different POU, but the problem is that I don't able to read the project info from the obj list. Following of this message there is my python script. Can you help my? Best regards Francesco # encoding:utf-8 # We enable the new python 3 print syntax from __future__ import print_function import os import shutil import time import sys from datetime import datetime print("--- Saving files in the project: ---") print("sys.argv: ", len(sys.argv), " elements:") for arg in sys.argv: print(" - ", arg) if (len(sys.argv)>1): folderExportName = sys.argv[1] print(" folderExportName: ", folderExportName) exportPath = sys.argv[2]+ sys.argv[3]+ "\\"+ sys.argv[1] print(" File path: ", exportPath) # git has_repo=False #save_folder=r'E:\Tmp\ControlPlugins\ControlPlugins\Export' save_folder = exportPath if not os.path.exists(save_folder): os.makedirs(save_folder) else: a=os.listdir(save_folder) for f in a: if not f.startswith("."): sub_path= os.path.join(save_folder,f) if os.path.isdir(sub_path): shutil.rmtree(sub_path) else: os.remove(sub_path) elif f==".git": has_repo=True info={} type_dist={ '792f2eb6-721e-4e64-ba20-bc98351056db':'pm', #property method '2db5746d-d284-4425-9f7f-2663a34b0ebc':'dut', #dut 'adb5cb65-8e1d-4a00-b70a-375ea27582f3':'lib', #lib manager 'f89f7675-27f1-46b3-8abb-b7da8e774ffd':'m', #method no ret '8ac092e5-3128-4e26-9e7e-11016c6684f2':'act', #action '6f9dac99-8de1-4efc-8465-68ac443b7d08':'pou', #pou '6654496c-404d-479a-aad2-8551054e5f1e':'itf', #interface '738bea1e-99bb-4f04-90bb-a7a567e74e3a':'', #folder 'ffbfa93a-b94d-45fc-a329-229860183b1d':'gvl', #global var '5a3b8626-d3e9-4f37-98b5-66420063d91e':'prop', #property '2bef0454-1bd3-412a-ac2c-af0f31dbc40f':'tl', #textlist '63784cbb-9ba0-45e6-9d69-babf3f040511':'gtl', #global textlist '225bfe47-7336-4dbc-9419-4105a7c831fa':'dev', #device 'ae1de277-a207-4a28-9efb-456c06bd52f3':'tc', #task configuration 'f8a58466-d7f6-439f-bbb8-d4600e41d099':'m', #method with ret '261bd6e6-249c-4232-bb6f-84c2fbeef430':'gvl', #gvl_Persistent '98a2708a-9b18-4f31-82ed-a1465b24fa2d':'task', #task '085afe48-c5d8-4ea5-ab0d-b35701fa6009':'progInfo'#project information }; def save(text,path,name,tp): if not tp: tp='' else: tp='.'+tp+'.txt' with open(os.path.join(path,name+tp),'w') as f: f.write(text.encode('utf-8')) def print_tree(treeobj, depth, path): global info #record current Path curpath=path isfolder=False t='' #text tp='' #type # get object name name = treeobj.get_name(False) id = treeobj.type.ToString() if id in type_dist: tp = type_dist[treeobj.type.ToString()] #Print all type of objects #print("--Name: ", tp) else: info[id]=name if treeobj.is_device: deviceid = treeobj.get_device_identification() t = 'type='+str(deviceid.type) +'\nid=' +str(deviceid.id) + '\nver='+ str(deviceid.version) if tp == "progInfo": print("-- There is prog info, ", tp) print("-- It has textual declaration: , ", treeobj.has_textual_declaration) print("-- It has textual implementation: , ", treeobj.has_textual_implementation) print("-- It is folder: , ", treeobj.is_folder) print("-- It is children: , ", treeobj.get_children(False)) print("-- It is children len: , ", len(treeobj.get_children(False))) print("-- It is progInfo type: , ", type(treeobj.ScriptProject)) #for child in treeobj.get_children(False): # print_tree(child, depth+1,curpath) try: if treeobj.is_folder : #system.ui.prompt('folder:'+u, PromptChoice.YesNo, PromptResult.Yes) isfolder=true pass except: pass if treeobj.has_textual_declaration : t=t+'(*#-#-#-#-#-#-#-#-#-#---Declaration---#-#-#-#-#-#-#-#-#-#-#-#-#*)\r\n' a=treeobj.textual_declaration t=t+a.text if treeobj.has_textual_implementation: t=t+'(*#-#-#-#-#-#-#-#-#-#---Implementation---#-#-#-#-#-#-#-#-#-#-#-#-#*)\r\n' a=treeobj.textual_implementation t=t+a.text if treeobj.has_textual_declaration and not treeobj.has_textual_implementation: t=t+'(*#-#-#-#-#-#-#-#-#-#---NOT Implementation visible---#-#-#-#-#-#-#-#-#-#-#-#-#*)\r\n' if treeobj.is_task : exports=[treeobj] projects.primary.export_native(exports,os.path.join(curpath,name+'.task')) if treeobj.is_libman: exports=[treeobj] projects.primary.export_native(exports,os.path.join(curpath,name+'.lib')) if treeobj.is_textlist: treeobj.export(os.path.join(curpath,name+'.tl')) children = treeobj.get_children(False) if children or isfolder: if tp: curpath=os.path.join(curpath,name+'.'+tp) else: curpath=os.path.join(curpath,name) if not os.path.exists(curpath): os.makedirs(curpath) if t: save(t,curpath,name,tp) for child in treeobj.get_children(False): print_tree(child, depth+1,curpath) for obj in projects.primary.get_children(): print_tree(obj,0,save_folder) with open(os.path.join(save_folder,'ExportInfo.txt'),'w') as f: now = datetime.now() infTimeExecution = now.strftime("%Y-%m-%d %H:%M:%S") f.write("Export date and time: "+infTimeExecution + "\r\n" + str(info)) print("--- Script finished. ---") #system.ui.info('save ok') projects.primary.close()
Last updated: 2024-04-30
Post by martin-k on Beispieldateien finden / Inhalt der Packages
CODESYS Forge
talk
(Post)
Hallo, mal wieder war der Fehler vor dem Computer, bzw. waren es die Programmierer. Die Dateien sind tatsächlich im Ordner C:\Users\BENUZTERNAME\CODESYS Examples Aber nicht in dem der vor dem Computer sitzt, sondern im Administrator-Verzeichnis. Eine mächtig dämliche Sache. Und das alles ohne Hinweise in irgendwelchen Anleitungen oder Meldungsfenster beim installieren. Bei meiner suche mit *.project habe ich natürlich keine Adminrechte, deswegen wurde mir nichts angezeigt. Danke an alle die meine Beiträge gelesen haben. Danke an alle die darüber nachgedacht haben :-) Vielleicht hilft mein Thread mal jemandem. Gruß Martin PS: Mache Firmen nennen die Beispieldateien nicht Examples sondern Samples.
Last updated: 2023-11-17
Post by eschwellinger on SP19 Runtime Zugriff auf lokales Dateisystem
CODESYS Forge
talk
(Post)
seit SP19 nur noch im PLcLogic pfad. c:\ProgramData\CODESYS...usw datein schreiben lesen [SysFile] PlaceholderFilePath.1=/tmp, $TMP$ PlaceholderFilePath.2=/media/usb, $USB$ PlaceholderFilePath.2.Volatile=1 Seit der Behebung kann der IEC-Code aus Security-Gründen nur noch auf das Arbeitsverzeichnis PLCLogic zugreifen. Sollte auf Dateien außerhalb dieses Pfades zugegriffen werden müssen, dann können diese per Platzhalter bekannt gemacht werden und sind dann zugreifbar. Darüber hinaus kann weiterhin ForceIecFilePath=0 gesetzt werden, um das bisherige Verhalten wiederherzustellen. Von letzterem raten wir aber dringend ab, da dann der IEC-Code wieder auf das gesamte Filesystem zugreifen kann. Daher sollte beides nur nach einer eingehenden Securitybewertung erfolgen.
Last updated: 2023-11-23
Post by seppi on Raspberry 4 I²C with Arduino UNO R3
CODESYS Forge
talk
(Post)
Hallo zusammen Ich möchte meinen Arduino und meinen PI miteinander kommunizieren lassen via I²C doch ich habe keine Ahnung wie das funktionieren soll. Aber es müsste funktionieren da es viele Beispiele dazu gibt jedoch wurde keines der Beispiele mit Codesys programmiert sondern über Python. Mein PI wird der Master sein und soll mit dem Slave (Arduino) Messdaten wie Geschwindigkeit und Akkukapazität und so weiter austauschen. Wenn mir bei meinen Problem jemand weiterhelfen könnte währe ich sehr Dankbar. Hier noch ein Link der Hilfreich sein könnte. Ich finde aber die angegeben Bibliotheken nicht. https://forge.codesys.com/forum/en/773/genmed-documentation.pdf
Last updated: 2023-12-03
Post by royw on Profinet Library für C#
CODESYS Forge
talk
(Post)
Hallo, ich weiß nicht ob ich hier richtig bin und ob es überhaupt möglich ist ... Ich suche eine Möglichkeit ein Profinet Device mit Record Read und Write anzusprechen. Eigentlich brauche ich nur sehr wenige Kommandos um unser Device zu konfigurieren. Das bedeutet setzen der MAC Adresse und einer Seriennummer. Das würden wir gern aus einem C# Programm herus machen. Nun sind wir auf der Suche nach einer Bibliothek o.ä. . Da man es ja auch aus Codesys heraus machen, dachte ich mir, gibt es eventuell eine DLL o.ä. die man dafür nutzen könnte. Wie gesagt wir wollen keine Realtime Abfragen der zyklischen Daten sondern lediglich Record read/write. Hat da jemand einen helfenden Hinweis ? Schon mal vielen Dank im Voraus
Last updated: 2023-12-22
Post by enginear on auf Feldbusvariablen über Array zugreifen
CODESYS Forge
talk
(Post)
Hallo, ich würde gerne die Variablen, die ich mit Ethernet/IP übertrage gerne in meinem Programm möglichst einfach ansprechen. Ist es möglich die übertragenen Variablen über ein Array direkt anzusprechen? Ich kann zwar die Variablen alle händisch benennen und dann im Programm auf diese zugreifen, aber wenn es viele Variablen sind und ich diese alle der Reihe nach in einer Schleife durchgehen möchte, so ist das schon viel Code der dafür notwendig ist. Bei mir werden die Variablen in Codesys unter dem Ordner (kann man aufklappen) 'Exclusive Owner' angezeigt. Da klingt es doch naheliegend, dass man direkt über den Ordnernamen die Variablen per Indexierung oder ähnliches ansprechen kann. vielen Dank und viele Grüße enginear
Last updated: 2024-02-23
Post by rost on Rezeptur speichern
CODESYS Forge
talk
(Post)
Servus beianand, eine kurze Vorstellung, da ich hier neu bin Wohne und Arbeite in Bayern seit 27 Jahren als Programmierer. Mit Codesys arbeite ich seit 4 Jahren. Für mein Projekt hab ich die einfache Rezepturverwaltung verwendet. Bis jetzt alles unproblematisch, hab aber jetzt ein wenig um- und aufgeräumt, prinzipiell aber nicht verändert. Ich kann Rezepturen mit neuem Namen speichern, wenn ich aber den gleichen Namen verwende, öffnete sich bisher ein Dialogfenster mit "File already exists..." Neu öffnet sich aber der Dialog mit kryptischen Zeichen ohne Eingabemöglichkeit und ohne das Fenster wieder schließen zu können. Dann kann ich nur noch aus und wieder einschalten. Hat jemand eine Idee?
Last updated: 2024-03-01
Post by rost on Rezeptur speichern
CODESYS Forge
talk
(Post)
Servus beianand, eine kurze Vorstellung, da ich hier neu bin Wohne und Arbeite in Bayern seit 27 Jahren als Programmierer. Mit Codesys arbeite ich seit 4 Jahren. Für mein Projekt hab ich die einfache Rezepturverwaltung verwendet. Bis jetzt alles unproblematisch, hab aber jetzt ein wenig um- und aufgeräumt, prinzipiell aber nicht verändert. Ich kann Rezepturen mit neuem Namen speichern, wenn ich aber den gleichen Namen verwende, öffnete sich bisher ein Dialogfenster mit "File already exists..." Neu öffnet sich aber der Dialog mit kryptischen Zeichen ohne Eingabemöglichkeit und ohne das Fenster wieder schließen zu können. Dann kann ich nur noch aus und wieder einschalten. Hat jemand eine Idee?
Last updated: 2024-03-01
To search for an exact phrase, put it in quotes. Example: "getting started docs"
To exclude a word or phrase, put a dash in front of it. Example: docs -help
To search on specific fields, use these field names instead of a general text search. You can group with AND
or OR
.