I am creating a model in ArcPro for a suitability analysis. I have 3 factors that will influence my final score. Right now I run a series of calculations to determine a score for each factor. What I would like to do is add up the score from each factor to determine a final score (Score A + Score B + Score C).
I would like to use a join/merge or other tool to create a table that contains 1 polygon feature for each area of interest (OBJECTID) populated with a score fields from 3 separate tables. The merge tool appends all of the tables together like this:
OBJECTID | A_SCORE | B_SCORE | C_SCORE | Final_SCORE |
1 | 0 | 0 | 0 | 0 |
1 | 0 | 2.5 | 0 | 2.5 |
1 | 0 | 0 | 18.13 | 18.13 |
2 | 5 | 0 | 0 | 5 |
2 | 0 | 5 | 0 | 5 |
2 | 0 | 0 | 21.8 | 21.8 |
but what I would like to see is 1 row per OBJECTID which should look like this:
OBJECTID | A_SCORE | B_SCORE | C_SCORE | Final_SCORE |
1 | 0 | 2.5 | 18.13 | 20.63 |
2 | 5 | 5 | 21.8 | 31.8 |
Which tools should I be using to accomplish this? I am currently only including 3 factors but will have 9 in total so I'm hoping there are some batch tools available to make the model less complicated.
As with anything like this, there are lots of ways to approach aggregating the data the way you describe. The easiest way I can think of is using the "Summarize" tool found in the Attribute Table. In your case, you would open the attribute table, right-click on the "ObjectID" field and then click "Summarize". Set all of your "*_SCORE" fields up in the "Statistic Fields" to sum, and the "Case Field" should already se set to the Object ID. This will result in a new table that will have one row for every unique ID (Case Field entry) and fields for every Statistics Field you defined with sums of all of the records used to combine it. You'll also get a count for each row indicating how many were aggregated. Hope this helps
Do you have the data as a feature class?
I hope you have Added the "Final_Score" Field, and Calculated the field with the expression that you mentioned.
Then, you could use Dissolve tool, as mentioned below
It sounds like the dissolve tool would work but my data is stored in a series of tables, not feature classes, so I'm not sure if it will work.
My workaround for now has been to export one of the tables into a new table (Final_SCORE), join the score field from each of the other tables (2 joins) and then run a series of calculations to get my final score. I would like to slim it down if possible though since I will be adding more factors in the near future.