<?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 script Update Cursor in Python Questions</title>
    <link>https://community.esri.com/t5/python-questions/python-script-update-cursor/m-p/497710#M39095</link>
    <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;thanks man, it works perfectly.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;learning python on the fly but this certainly helps!&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
    <pubDate>Sat, 21 Nov 2015 00:28:19 GMT</pubDate>
    <dc:creator>jameljoseph</dc:creator>
    <dc:date>2015-11-21T00:28:19Z</dc:date>
    <item>
      <title>Python script Update Cursor</title>
      <link>https://community.esri.com/t5/python-questions/python-script-update-cursor/m-p/497707#M39092</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;I have a table in my geodatabase that contains fields with some values and empty fields.&amp;nbsp; &lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;What I am trying to do is first let the user select the table to use, then add values to 2 fields based on values in another field but I am a beginner with python so I was wondering if someone here knows what is wrong with my script.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Thank you&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;import arcpy&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;# Get table parameter&lt;/P&gt;&lt;P&gt;param1 = arcpy.Parameter(&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; displayname="Roads")&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; &lt;/P&gt;&lt;P&gt;# Open table to edit&lt;/P&gt;&lt;P&gt;GeoDBLocation = open (param1, 'r+')&lt;/P&gt;&lt;P&gt;Fields["LABEL", "SYMBOL", "SYM_TYPE"]&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;# Add data&lt;/P&gt;&lt;P&gt;cur = arcpy.UpdateCursor(GeoDBLocation)&lt;/P&gt;&lt;P&gt;For row in cur:&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; If row.getvalue("LABEL") == "H":&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; row.setvalue("SYMBOL", "3.01")&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; row.setvalue("SYM_TYPE", "S")&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; Elif row.getvalue("LABEL") == "L":&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; row.setvalue("SYMBOL", "3.02")&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; row.setvalue("SYM_TYPE", "F")&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; Else:&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; row.setvalue("SYMBOL", "0.01")&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; row.setvalue("SYM_TYPE", "O")&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; cursor.updateRow(row)&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; &lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;#Delete cursor&lt;/P&gt;&lt;P&gt;del row&lt;/P&gt;&lt;P&gt;del cur&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; &lt;/P&gt;&lt;P&gt;#close file&lt;/P&gt;&lt;P&gt;GeoDBLocation.close&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Fri, 20 Nov 2015 20:29:52 GMT</pubDate>
      <guid>https://community.esri.com/t5/python-questions/python-script-update-cursor/m-p/497707#M39092</guid>
      <dc:creator>jameljoseph</dc:creator>
      <dc:date>2015-11-20T20:29:52Z</dc:date>
    </item>
    <item>
      <title>Re: Python script Update Cursor</title>
      <link>https://community.esri.com/t5/python-questions/python-script-update-cursor/m-p/497708#M39093</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Hi Jamel,&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Try using the &lt;A href="https://pro.arcgis.com/en/pro-app/arcpy/data-access/updatecursor-class.htm" rel="nofollow noopener noreferrer" target="_blank"&gt;arcpy.da.UpdateCursor&lt;/A&gt;.&amp;nbsp; It is much faster that the arcpy.UpdateCursor.&amp;nbsp; Below is an example:&lt;/P&gt;&lt;PRE class="lia-code-sample line-numbers language-none"&gt;import arcpy

param1 = arcpy.GetParameterAsText(0)

with arcpy.da.UpdateCursor(param1, ["LABEL", "SYMBOL", "SYM_TYPE"]) as cursor:
&amp;nbsp;&amp;nbsp;&amp;nbsp; for row in cursor:
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; if row[0] == "H":
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; row[1] = "3.01"
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; row[2] = "S"
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; elif row[0] == "L":
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; row[1] = "3.02"
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; row[2] = "F"
&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; row[1] = "0.01"
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; row[2] = "0"
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; cursor.updateRow(row)

del cursor&lt;/PRE&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;You can then &lt;A href="http://desktop.arcgis.com/en/desktop/latest/analyze/creating-tools/a-quick-tour-of-creating-script-tools.htm" rel="nofollow noopener noreferrer" target="_blank"&gt;add this script to a toolbox&lt;/A&gt;.&amp;nbsp; You can setup your parameters like the screen shot below to allow users to select a feature class to run the script on:&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;IMG alt="Screen1.PNG" class="image-1 jive-image" src="https://community.esri.com/legacyfs/online/146195_Screen1.PNG" style="height: auto;" /&gt;&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Sat, 11 Dec 2021 21:52:31 GMT</pubDate>
      <guid>https://community.esri.com/t5/python-questions/python-script-update-cursor/m-p/497708#M39093</guid>
      <dc:creator>JakeSkinner</dc:creator>
      <dc:date>2021-12-11T21:52:31Z</dc:date>
    </item>
    <item>
      <title>Re: Python script Update Cursor</title>
      <link>https://community.esri.com/t5/python-questions/python-script-update-cursor/m-p/497709#M39094</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;There are quite a few errors in your code. I've outline them below and also included a copy of what the correct code should look like. I'm assuming that you're writing this for a script tool.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;PRE class="lia-code-sample line-numbers language-none"&gt;import arcpy


''' 
You'd use Parameter if you needed to create one. In this case you need to pull
a value from the tool.
'''
# Get table parameter
param1 = arcpy.Parameter(displayname="Roads") 


'''
open is used to open flat files. This is not going to work with opening a 
file geodatabase. The software will handle opening this for you
'''
# Open table to edit
GeoDBLocation = open (param1, 'r+')


'''
You're using a variable below called fields and it hasn't been defined. Python
also doesn't support indexing with words.
'''
Fields["LABEL", "SYMBOL", "SYM_TYPE"]


# Add data
cur = arcpy.UpdateCursor(GeoDBLocation)


'''
python is a case sensitive languague. The words for, if, elif, and else should 
be lowercase. Also, the getValue method needs a capital V.
'''
For row in cur:
&amp;nbsp;&amp;nbsp;&amp;nbsp; If row.getvalue("LABEL") == "H":
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; row.setvalue("SYMBOL", "3.01")
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; row.setvalue("SYM_TYPE", "S")
&amp;nbsp;&amp;nbsp;&amp;nbsp; Elif row.getvalue("LABEL") == "L":
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; row.setvalue("SYMBOL", "3.02")
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; row.setvalue("SYM_TYPE", "F")
&amp;nbsp;&amp;nbsp;&amp;nbsp; Else:
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; row.setvalue("SYMBOL", "0.01")
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; row.setvalue("SYM_TYPE", "O")
&amp;nbsp;&amp;nbsp;&amp;nbsp; cursor.updateRow(row)




#Delete cursor
del row
del cur


import arcpy


# Get table parameter
param1 = arcpy.GetParameterAsText(0)
fields = ["LABEL", "SYMBOL", "SYM_TYPE"]


cur = arcpy.UpdateCursor(param1)


for row in cur:
&amp;nbsp;&amp;nbsp;&amp;nbsp; value = row.getValue("LABEL")
&amp;nbsp;&amp;nbsp;&amp;nbsp; if value == "H":
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; row.setValue("SYMBOL", 3.01)
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; row.setValue("SYM_TYPE", "S")
&amp;nbsp;&amp;nbsp;&amp;nbsp; elif value == "L":
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; row.setValue("SYMBOL", 3.02)
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; row.setValue("SYM_TYPE", "F")&amp;nbsp;&amp;nbsp;&amp;nbsp;&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; row.setValue("SYMBOL", 0.01)
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; row.setValue("SYM_TYPE", "O")&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 
del row
del cur&lt;/PRE&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Sat, 11 Dec 2021 21:52:33 GMT</pubDate>
      <guid>https://community.esri.com/t5/python-questions/python-script-update-cursor/m-p/497709#M39094</guid>
      <dc:creator>FreddieGibson</dc:creator>
      <dc:date>2021-12-11T21:52:33Z</dc:date>
    </item>
    <item>
      <title>Re: Python script Update Cursor</title>
      <link>https://community.esri.com/t5/python-questions/python-script-update-cursor/m-p/497710#M39095</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;thanks man, it works perfectly.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;learning python on the fly but this certainly helps!&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Sat, 21 Nov 2015 00:28:19 GMT</pubDate>
      <guid>https://community.esri.com/t5/python-questions/python-script-update-cursor/m-p/497710#M39095</guid>
      <dc:creator>jameljoseph</dc:creator>
      <dc:date>2015-11-21T00:28:19Z</dc:date>
    </item>
    <item>
      <title>Re: Python script Update Cursor</title>
      <link>https://community.esri.com/t5/python-questions/python-script-update-cursor/m-p/497711#M39096</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;thanks jake, this works as well.&amp;nbsp; Learnign so much in one day here!&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Sat, 21 Nov 2015 00:30:12 GMT</pubDate>
      <guid>https://community.esri.com/t5/python-questions/python-script-update-cursor/m-p/497711#M39096</guid>
      <dc:creator>jameljoseph</dc:creator>
      <dc:date>2015-11-21T00:30:12Z</dc:date>
    </item>
  </channel>
</rss>

