<?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 Geometries from Javascript API to Python in ArcGIS JavaScript Maps SDK Questions</title>
    <link>https://community.esri.com/t5/arcgis-javascript-maps-sdk-questions/geometries-from-javascript-api-to-python/m-p/7014#M676</link>
    <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;I'm working on a geoprocessing tool to export my online web application's map graphics to any other format via ArcGIS Server.&amp;nbsp; I want to be able to send the geometries to the server and return a KML, Shapefile or whatever format I prefer.&amp;nbsp; Since there is no standard method in the API to convert geometries to other formats, I have created my own procedure.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;An example of the list of geometries being sent from the web app to the server look like this with Web Mercator coordinates:&lt;/P&gt;&lt;PRE class="lia-code-sample line-numbers language-none"&gt;[
&amp;nbsp;&amp;nbsp; [[2097634.02,-4008451.29],[2097514.11,-4008426.54],[2097543.19,-4008329.14],[2097671.5,-4008357.4],[2097634.02,-4008451.29]],
&amp;nbsp;&amp;nbsp; ...
]&lt;/PRE&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;The geometries list is built on the web app side with the following function:&lt;/P&gt;&lt;PRE class="lia-code-sample line-numbers language-none"&gt;function exportGeometries(){
&amp;nbsp; var exportGeoms = '[';
&amp;nbsp; // each graphic feature geometry
&amp;nbsp; for (g=0; g &amp;lt;= map.graphics.graphics.length - 1; g++){
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; exportGeoms += (g &amp;gt; 0 ? ',' : '');
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; rings = &lt;SPAN style="color: rgba(0, 0, 0, 0); font-family: Consolas, 'Courier New', Courier, mono, serif; font-size: 12px;"&gt;map.graphics&lt;/SPAN&gt;.graphics&lt;G&gt;.geometry.rings;&lt;/G&gt;
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; // each ring in the geometry
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; polyring = '[';
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; for (r=0; r &amp;lt;= rings.length - 1; r++){
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; ring = rings&lt;R&gt;;&lt;/R&gt;
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; // each point in the ring
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; for (pnt=0; pnt &amp;lt;= ring.length - 1; pnt++){
&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;&amp;nbsp;&amp;nbsp; polyring += (pnt &amp;gt; 0 ? ',' : '');
&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;&amp;nbsp;&amp;nbsp; polyring += '[' + ring[pnt][0] + ',' + ring[pnt][1] + ']';
&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;&amp;nbsp;&amp;nbsp;&amp;nbsp; }
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; polyring += ']';
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; exportGeoms += polyring;
&amp;nbsp; }
&amp;nbsp; exportGeoms += ']';
}&lt;/PRE&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;The Python script tool on the server side needs to be able to read the list of geometries.&amp;nbsp; Just using arcpy.GetParameter() to read the list of geometries as a list object is not sufficient, because Python receives it as a unicode object. I've found a python module (ast) that &lt;STRONG&gt;converts the unicode object to a standard list object&lt;/STRONG&gt; that can be iterated in Python with a for loop to create a new feature class that can be converted:&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;PRE class="lia-code-sample line-numbers language-none"&gt;import arcpy, ast
&lt;SPAN style="line-height: 1.5;"&gt;geometries = arcpy.GetParameter(0)&lt;/SPAN&gt;
&lt;SPAN&gt;geomList = ast.literal_eval(geometries)&lt;/SPAN&gt;

sr = arcpy.SpatialReference(102100)
newfc = arcpy.CreateFeatureclass_management(arcpy.env.scratchWorkspace, "webgeom", "POLYGON","","","",sr)
cur = arcpy.da.InsertCursor(newfc, ("SHAPE@"))

&lt;SPAN style="font-size: 9pt; line-height: 12pt;"&gt;for polyring in geometries:&lt;/SPAN&gt;
&amp;nbsp;&amp;nbsp; array = arcpy.Array()
&amp;nbsp;&amp;nbsp; for p in polyring:&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; array.add(arcpy.Point(p[0],p[1]))
&amp;nbsp;&amp;nbsp; polygon = arcpy.Polygon(array,sr)
&amp;nbsp;&amp;nbsp; cur.insertRow([polygon])&amp;nbsp;&amp;nbsp; 
)&lt;/PRE&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;The new Feature Class can now be converted to any other format with the standard toolbox tools.&amp;nbsp; The Python script can be integrated into the final model or script that is published as a GP service that saves the converted object on the web server and returns a URL link as output.&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
    <pubDate>Fri, 10 Dec 2021 20:18:00 GMT</pubDate>
    <dc:creator>FC_Basson</dc:creator>
    <dc:date>2021-12-10T20:18:00Z</dc:date>
    <item>
      <title>Geometries from Javascript API to Python</title>
      <link>https://community.esri.com/t5/arcgis-javascript-maps-sdk-questions/geometries-from-javascript-api-to-python/m-p/7014#M676</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;I'm working on a geoprocessing tool to export my online web application's map graphics to any other format via ArcGIS Server.&amp;nbsp; I want to be able to send the geometries to the server and return a KML, Shapefile or whatever format I prefer.&amp;nbsp; Since there is no standard method in the API to convert geometries to other formats, I have created my own procedure.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;An example of the list of geometries being sent from the web app to the server look like this with Web Mercator coordinates:&lt;/P&gt;&lt;PRE class="lia-code-sample line-numbers language-none"&gt;[
&amp;nbsp;&amp;nbsp; [[2097634.02,-4008451.29],[2097514.11,-4008426.54],[2097543.19,-4008329.14],[2097671.5,-4008357.4],[2097634.02,-4008451.29]],
&amp;nbsp;&amp;nbsp; ...
]&lt;/PRE&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;The geometries list is built on the web app side with the following function:&lt;/P&gt;&lt;PRE class="lia-code-sample line-numbers language-none"&gt;function exportGeometries(){
&amp;nbsp; var exportGeoms = '[';
&amp;nbsp; // each graphic feature geometry
&amp;nbsp; for (g=0; g &amp;lt;= map.graphics.graphics.length - 1; g++){
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; exportGeoms += (g &amp;gt; 0 ? ',' : '');
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; rings = &lt;SPAN style="color: rgba(0, 0, 0, 0); font-family: Consolas, 'Courier New', Courier, mono, serif; font-size: 12px;"&gt;map.graphics&lt;/SPAN&gt;.graphics&lt;G&gt;.geometry.rings;&lt;/G&gt;
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; // each ring in the geometry
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; polyring = '[';
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; for (r=0; r &amp;lt;= rings.length - 1; r++){
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; ring = rings&lt;R&gt;;&lt;/R&gt;
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; // each point in the ring
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; for (pnt=0; pnt &amp;lt;= ring.length - 1; pnt++){
&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;&amp;nbsp;&amp;nbsp; polyring += (pnt &amp;gt; 0 ? ',' : '');
&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;&amp;nbsp;&amp;nbsp; polyring += '[' + ring[pnt][0] + ',' + ring[pnt][1] + ']';
&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;&amp;nbsp;&amp;nbsp;&amp;nbsp; }
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; polyring += ']';
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; exportGeoms += polyring;
&amp;nbsp; }
&amp;nbsp; exportGeoms += ']';
}&lt;/PRE&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;The Python script tool on the server side needs to be able to read the list of geometries.&amp;nbsp; Just using arcpy.GetParameter() to read the list of geometries as a list object is not sufficient, because Python receives it as a unicode object. I've found a python module (ast) that &lt;STRONG&gt;converts the unicode object to a standard list object&lt;/STRONG&gt; that can be iterated in Python with a for loop to create a new feature class that can be converted:&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;PRE class="lia-code-sample line-numbers language-none"&gt;import arcpy, ast
&lt;SPAN style="line-height: 1.5;"&gt;geometries = arcpy.GetParameter(0)&lt;/SPAN&gt;
&lt;SPAN&gt;geomList = ast.literal_eval(geometries)&lt;/SPAN&gt;

sr = arcpy.SpatialReference(102100)
newfc = arcpy.CreateFeatureclass_management(arcpy.env.scratchWorkspace, "webgeom", "POLYGON","","","",sr)
cur = arcpy.da.InsertCursor(newfc, ("SHAPE@"))

&lt;SPAN style="font-size: 9pt; line-height: 12pt;"&gt;for polyring in geometries:&lt;/SPAN&gt;
&amp;nbsp;&amp;nbsp; array = arcpy.Array()
&amp;nbsp;&amp;nbsp; for p in polyring:&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; array.add(arcpy.Point(p[0],p[1]))
&amp;nbsp;&amp;nbsp; polygon = arcpy.Polygon(array,sr)
&amp;nbsp;&amp;nbsp; cur.insertRow([polygon])&amp;nbsp;&amp;nbsp; 
)&lt;/PRE&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;The new Feature Class can now be converted to any other format with the standard toolbox tools.&amp;nbsp; The Python script can be integrated into the final model or script that is published as a GP service that saves the converted object on the web server and returns a URL link as output.&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Fri, 10 Dec 2021 20:18:00 GMT</pubDate>
      <guid>https://community.esri.com/t5/arcgis-javascript-maps-sdk-questions/geometries-from-javascript-api-to-python/m-p/7014#M676</guid>
      <dc:creator>FC_Basson</dc:creator>
      <dc:date>2021-12-10T20:18:00Z</dc:date>
    </item>
  </channel>
</rss>

