Skip to main content
Open

PythonCaller gets python code from attribute

Related products:Transformers
siennaatsafe
david_r
hkingsbury
danilo_fme
tcrossman
+29
  • siennaatsafe
    siennaatsafe
  • david_r
    david_r
  • hkingsbury
    hkingsbury
  • danilo_fme
    danilo_fme
  • tcrossman
    tcrossman
  • mattwilkie
    mattwilkie
  • lorenrouth
    lorenrouth
  • jackyd
    jackyd
  • olivier
    olivier
  • thdrg
    thdrg
  • koenterralytics
    koenterralytics
  • revesz
    revesz
  • victors
  • iangr
    iangr
  • tijs
    tijs
  • lde
    lde
  • esietinga
    esietinga
  • cwarren
    cwarren
  • carlm
    carlm
  • par_smars
  • kd
  • samisnunu
    samisnunu
  • ekkischeffler
    ekkischeffler
  • lau
    lau
  • roland.martin
    roland.martin
  • stipica.pavicic
    stipica.pavicic
  • jeroen
    jeroen
  • jneujens
    jneujens
  • taojunabc
    taojunabc
  • jpvo
    jpvo
  • jeand
    jeand
  • justinemarechal
    justinemarechal
  • hendrikh
  • mairesse
    mairesse

jpvo
Participant
  • Participant

I'd like to be able to maintain python scripts as .py files independant from my workspace (Like I do with sql scripts and SQLExecutor). The pythonCaller doens't allow to parse python code from an existing fme attribute.

That would be handy to implement an AttributeFileReader to read from the .py file and a PythonCaller to run the python script from the _file_content attribute.

Advantage: proper version control of the python scripts in GIT

8 replies

lau
Forum|alt.badge.img+3
  • November 24, 2017

... and add a rejected port?


jneujens
Forum|alt.badge.img
  • November 28, 2017

... and better debugging? :)


paalped
Contributor
Forum|alt.badge.img+5
  • Contributor
  • December 7, 2017

No problem, Here is a very simple non-safe example:

import fmeobjects # Template Class class FeatureCreator(object): def __init__(self): pass def input(self,feature): newFeature = fmeobjects.FMEFeature() with open('C:\\\\temp\\\\test.py','r') as pyf: for line in pyf.readlines(): if not line: break else: exec(line) self.pyoutput(newFeature) def close(self): # close method must be defined # # output features here to create the features # after reader features have been processed pass

And your c:\\temp\\test.py:

newFeature.addCoordinate(0,0,0) print 'new feature at 0,0,0'


davideagle
Contributor
Forum|alt.badge.img+21
  • Contributor
  • July 29, 2021

Just had exactly this request today. A prospect wanting to use FME to call GIT managed python code directly from the PythonCaller. The SQLExecutor has the ability to read SQL from an attribute so the same capability for the PythonCaller would be a starting position for this that would add some value.


tijs
Participant
Forum|alt.badge.img
  • Participant
  • November 23, 2022

To add to this proposed idea: support Python code that is managed by a git repository AND that runs within virtual environments that can’t interfere with any dependencies that FME has.

I wouldn't support the idea of including code in attributes, just a reference to the directory/file with the code. The workspace features could be stored in a temporary dataset rather than directly ported via the FME python library.

Ideally the log files of the FME job would also include all log output from the script.


LizAtSafe
Safer
Forum|alt.badge.img+15
  • Safer
  • February 8, 2024
The following idea has been merged into this idea:
jeand
All the votes have been transferred into this idea.

LizAtSafe
Safer
Forum|alt.badge.img+15
  • Safer
  • February 8, 2024
The following idea has been merged into this idea:
All the votes have been transferred into this idea.

LizAtSafe
Safer
Forum|alt.badge.img+15
  • Safer
  • February 8, 2024
The following idea has been merged into this idea:
All the votes have been transferred into this idea.

Cookie policy

We use cookies to enhance and personalize your experience. If you accept you agree to our full cookie policy. Learn more about our cookies.

 
Cookie settings