<?xml version="1.0" encoding="UTF-8"?>
<rss xmlns:content="http://purl.org/rss/1.0/modules/content/" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" xmlns:taxo="http://purl.org/rss/1.0/modules/taxonomy/" version="2.0">
  <channel>
    <title>topic Re: Python - how to create a success/failure log for each process in Python Questions</title>
    <link>https://community.esri.com/t5/python-questions/python-how-to-create-a-success-failure-log-for/m-p/698788#M54184</link>
    <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;For our scheduled task python scripts, we have it send an email with all the printed debug information, including &lt;SPAN style="font-family: 'courier new', courier;"&gt;&lt;A href="http://desktop.arcgis.com/en/desktop/latest/analyze/arcpy-functions/getmessages.htm" rel="nofollow noopener noreferrer" target="_blank"&gt;arcpy.GetMessages()&lt;/A&gt;​&lt;SPAN style="font-family: arial, helvetica, sans-serif;"&gt;. The script also creates an entry in a scheduled task log table we have in SDE (which is just a fancy way of using a file like Darren mentioned).&lt;/SPAN&gt;&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;SPAN style="font-family: arial, helvetica, sans-serif;"&gt;This is kind of how we set up our scripts (minus the email part).&lt;/SPAN&gt;&lt;/P&gt;&lt;PRE class="lia-code-sample line-numbers language-none"&gt;# -*- coding: utf-8 -*-
# ---------------------------------------------------------------------------
# Reg_MView2.py
# Created on: 2015-11-02 17:30:22.00000
#&amp;nbsp;&amp;nbsp; (generated by ArcGIS/ModelBuilder)
# Description:
# ---------------------------------------------------------------------------

def main():
&amp;nbsp;&amp;nbsp;&amp;nbsp; import arceditor&amp;nbsp; # Set the necessary product code
&amp;nbsp;&amp;nbsp;&amp;nbsp; import arcpy&amp;nbsp; # Import arcpy module
&amp;nbsp;&amp;nbsp;&amp;nbsp; import os

&amp;nbsp;&amp;nbsp;&amp;nbsp; try:
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; # Local variables:
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; sdeConn = "Database Connections\\Connection to GISREF.sde"
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; Var1 = os.path.join(sdeConn, "GIS.MVIEW1")
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; Var2 = os.path.join(sdeConn, "GIS.MVIEW2")
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; Var3 = os.path.join(sdeConn, "GIS.MVIEW3")
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; # ....etc

&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; # Process: Register with Geodatabase
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; for var in [Var1, Var2, Var3]:
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; print "Registering {}".format(var)
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; arcpy.RegisterWithGeodatabase_management(var)
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; print "Done\n"

&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; print "Script completed"

&amp;nbsp;&amp;nbsp;&amp;nbsp; except Exception as err:
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; # Write error message information
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; if err.message in arcpy.GetMessages(2):
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; ## Write all of the messages returned by the last ArcPy tool
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; print arcpy.GetMessages()
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; else:
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; ## Write non-ArcPy error message
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; print unicode(err).encode("utf-8")

&amp;nbsp;&amp;nbsp;&amp;nbsp; finally:
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; # Cleanup
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; arcpy.ClearWorkspaceCache_management()


if __name__ == '__main__':
&amp;nbsp;&amp;nbsp;&amp;nbsp; main()&lt;/PRE&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
    <pubDate>Sun, 12 Dec 2021 05:24:41 GMT</pubDate>
    <dc:creator>BlakeTerhune</dc:creator>
    <dc:date>2021-12-12T05:24:41Z</dc:date>
    <item>
      <title>Python - how to create a success/failure log for each process</title>
      <link>https://community.esri.com/t5/python-questions/python-how-to-create-a-success-failure-log-for/m-p/698785#M54181</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Hi everyone, a Python and ESRI newbie here.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;I wish to use a Python script to register a number of Oracle Materialised View with the geodatabase - please see my sample script below.&amp;nbsp; How can I instruct the script communicate to the user whether each MView has successfully been registered or not, ideally as a log file, or at least an open text file that the user can manually save at the end if they wish?&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Any guidance would be greatly appreciated&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Thanks,&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Robin&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;----------START-------------&lt;/P&gt;&lt;P&gt;# -*- coding: utf-8 -*-&lt;/P&gt;&lt;P&gt;# ---------------------------------------------------------------------------&lt;/P&gt;&lt;P&gt;# Reg_MView2.py&lt;/P&gt;&lt;P&gt;# Created on: 2015-11-02 17:30:22.00000&lt;/P&gt;&lt;P&gt;#&amp;nbsp;&amp;nbsp; (generated by ArcGIS/ModelBuilder)&lt;/P&gt;&lt;P&gt;# Description: &lt;/P&gt;&lt;P&gt;# ---------------------------------------------------------------------------&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;# Set the necessary product code&lt;/P&gt;&lt;P&gt;import arceditor&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;# Import arcpy module&lt;/P&gt;&lt;P&gt;import arcpy&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;# Local variables:&lt;/P&gt;&lt;P&gt;Var1 = "Database Connections\\Connection to GISREF.sde\\GIS.MVIEW1"&lt;/P&gt;&lt;P&gt;Var2 = "Database Connections\\Connection to GISREF.sde\\GIS.MVIEW2"&lt;/P&gt;&lt;P&gt;Var3 = "Database Connections\\Connection to GISREF.sde\\GIS.MVIEW3"&lt;/P&gt;&lt;P&gt;# ....etc&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;# Process: Register with Geodatabase&lt;/P&gt;&lt;P&gt;arcpy.RegisterWithGeodatabase_management(Var1)&lt;/P&gt;&lt;P&gt;arcpy.RegisterWithGeodatabase_management(Var2)&lt;/P&gt;&lt;P&gt;arcpy.RegisterWithGeodatabase_management(Var3)&lt;/P&gt;&lt;P&gt;# ....etc&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;print "Script completed"&lt;/P&gt;&lt;P&gt;-----------END-------&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Thu, 05 Nov 2015 11:10:30 GMT</pubDate>
      <guid>https://community.esri.com/t5/python-questions/python-how-to-create-a-success-failure-log-for/m-p/698785#M54181</guid>
      <dc:creator>robinburchfield1</dc:creator>
      <dc:date>2015-11-05T11:10:30Z</dc:date>
    </item>
    <item>
      <title>Re: Python - how to create a success/failure log for each process</title>
      <link>https://community.esri.com/t5/python-questions/python-how-to-create-a-success-failure-log-for/m-p/698786#M54182</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;I'm not familiar with Oracle and if you are expecting to capture some output from that, but as to what step in the script it has complete, you can add a "print" or an arcpy.AddMessage after each "RegisterWithGeodatabase" message.&amp;nbsp; Simplistic, but since you said you are a newbie with python, don't want to overlook it.&lt;/P&gt;&lt;P&gt;...edit:&lt;/P&gt;&lt;P&gt;oh...and opening up the GeoProseccing -&amp;gt; Results tab will show the output messages from your script.&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Thu, 05 Nov 2015 16:27:39 GMT</pubDate>
      <guid>https://community.esri.com/t5/python-questions/python-how-to-create-a-success-failure-log-for/m-p/698786#M54182</guid>
      <dc:creator>RebeccaStrauch__GISP</dc:creator>
      <dc:date>2015-11-05T16:27:39Z</dc:date>
    </item>
    <item>
      <title>Re: Python - how to create a success/failure log for each process</title>
      <link>https://community.esri.com/t5/python-questions/python-how-to-create-a-success-failure-log-for/m-p/698787#M54183</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Beyond &lt;A href="https://community.esri.com/migrated-users/2691"&gt;Rebecca Strauch, GISP&lt;/A&gt;​'s suggestion for prints and messages, the general Python methods for opening and writing files (e.g. text files) are found &lt;A href="https://docs.python.org/2/tutorial/inputoutput.html#reading-and-writing-files"&gt;here&lt;/A&gt;.&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Thu, 05 Nov 2015 16:59:09 GMT</pubDate>
      <guid>https://community.esri.com/t5/python-questions/python-how-to-create-a-success-failure-log-for/m-p/698787#M54183</guid>
      <dc:creator>DarrenWiens2</dc:creator>
      <dc:date>2015-11-05T16:59:09Z</dc:date>
    </item>
    <item>
      <title>Re: Python - how to create a success/failure log for each process</title>
      <link>https://community.esri.com/t5/python-questions/python-how-to-create-a-success-failure-log-for/m-p/698788#M54184</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;For our scheduled task python scripts, we have it send an email with all the printed debug information, including &lt;SPAN style="font-family: 'courier new', courier;"&gt;&lt;A href="http://desktop.arcgis.com/en/desktop/latest/analyze/arcpy-functions/getmessages.htm" rel="nofollow noopener noreferrer" target="_blank"&gt;arcpy.GetMessages()&lt;/A&gt;​&lt;SPAN style="font-family: arial, helvetica, sans-serif;"&gt;. The script also creates an entry in a scheduled task log table we have in SDE (which is just a fancy way of using a file like Darren mentioned).&lt;/SPAN&gt;&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;SPAN style="font-family: arial, helvetica, sans-serif;"&gt;This is kind of how we set up our scripts (minus the email part).&lt;/SPAN&gt;&lt;/P&gt;&lt;PRE class="lia-code-sample line-numbers language-none"&gt;# -*- coding: utf-8 -*-
# ---------------------------------------------------------------------------
# Reg_MView2.py
# Created on: 2015-11-02 17:30:22.00000
#&amp;nbsp;&amp;nbsp; (generated by ArcGIS/ModelBuilder)
# Description:
# ---------------------------------------------------------------------------

def main():
&amp;nbsp;&amp;nbsp;&amp;nbsp; import arceditor&amp;nbsp; # Set the necessary product code
&amp;nbsp;&amp;nbsp;&amp;nbsp; import arcpy&amp;nbsp; # Import arcpy module
&amp;nbsp;&amp;nbsp;&amp;nbsp; import os

&amp;nbsp;&amp;nbsp;&amp;nbsp; try:
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; # Local variables:
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; sdeConn = "Database Connections\\Connection to GISREF.sde"
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; Var1 = os.path.join(sdeConn, "GIS.MVIEW1")
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; Var2 = os.path.join(sdeConn, "GIS.MVIEW2")
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; Var3 = os.path.join(sdeConn, "GIS.MVIEW3")
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; # ....etc

&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; # Process: Register with Geodatabase
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; for var in [Var1, Var2, Var3]:
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; print "Registering {}".format(var)
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; arcpy.RegisterWithGeodatabase_management(var)
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; print "Done\n"

&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; print "Script completed"

&amp;nbsp;&amp;nbsp;&amp;nbsp; except Exception as err:
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; # Write error message information
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; if err.message in arcpy.GetMessages(2):
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; ## Write all of the messages returned by the last ArcPy tool
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; print arcpy.GetMessages()
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; else:
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; ## Write non-ArcPy error message
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; print unicode(err).encode("utf-8")

&amp;nbsp;&amp;nbsp;&amp;nbsp; finally:
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; # Cleanup
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; arcpy.ClearWorkspaceCache_management()


if __name__ == '__main__':
&amp;nbsp;&amp;nbsp;&amp;nbsp; main()&lt;/PRE&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Sun, 12 Dec 2021 05:24:41 GMT</pubDate>
      <guid>https://community.esri.com/t5/python-questions/python-how-to-create-a-success-failure-log-for/m-p/698788#M54184</guid>
      <dc:creator>BlakeTerhune</dc:creator>
      <dc:date>2021-12-12T05:24:41Z</dc:date>
    </item>
  </channel>
</rss>

