arcpy.mp.ArcGISProject .aprx lock issue

3875
18
03-20-2024 10:09 AM
__JackCharde__
Regular Contributor

Hey Everyone,

I wrote a python script for a client that extracts a project template to a new folder, manipulates the data and layouts in that new project, creates PDFs, saves a copy of that extracted project file with the current month/year, and then tries to delete the extracted project. The deletion always fails, and my VS Code terminal or the GP tool I built the script for says it's because the project is open somewhere.

I have tried deleting every variable that references the project, maps, layouts, elements, all arcpy.mp classes for that matter, and it still always fails.

Even if I close Pro where I ran the GP tool, or close VS Code where I was debugging the script and then go to File Explorer to delete the extracted Pro project, File Explorer says I can't because the file is open somewhere, which it is not when looking at my computer. 

Has anyone encountered this, and/or know a way around it?

Thanks!

- Jack C

18 Replies
Eugene_Adkins
Frequent Contributor

I have no experience with the workflow you’re referencing but I wonder if the project has any feature services as a data source? Until the service is shutdown I would guess an error similar to this would occur. This is only a complete guess.

0 Kudos
__JackCharde__
Regular Contributor

Hey Eugene,

I appreciate the reply. Currently, all data sources reference file geodatabase feature classes. When this issue first occurred, I checked Task Manager's Processes and Details panes to see if anything related to Pro was still active and did see ArcGISPro.exe in the Details pane, even though Pro was not open. I found that odd, but then didn't see it again, even though the issue persisted.

0 Kudos
MErikReedAugusta
MVP Regular Contributor

My understanding of the lock behavior is that lock files are created and stored somewhere in the directory for GDBs, and I would assume something similar is happening for the APRX.  If that lock file isn't properly cleaned up, then the software assumes someone somewhere is using it, even if they aren't.

It's like seeing antibodies and assuming the presence of a disease, even if the antibodies are just left behind and the disease was eradicated.

------------------------------
M Reed
"The pessimist may be right oftener than the optimist, but the optimist has more fun, and neither can stop the march of events anyhow." — Lazarus Long, in Time Enough for Love, by Robert A. Heinlein
0 Kudos
Robert_LeClair
Esri Esteemed Contributor

So there was an enhancement request, ENH-000140298 - Add a method to the arcpy.mp.ArcGISProject() object that will close the project and release locks held by a script.  But it was marked as "will not be addressed."  The explanation was "Locks on a project file can be eliminated by either closing the Python shell (vs the script editor) or by calling del on the appropriate variables. The method has little value when run in a script outside of the application and also inside the application."

__JackCharde__
Regular Contributor

Hey Robert,

Thanks for the reply and info about that enhancement request. The problem is, however, that I do delete all appropriate variables in an attempt to remove a lock, and it still doesn't work. I decided to switch from Extract Package to aprx.saveACopy(). Somehow when I run my GP tool with Pro open, even though the project it's working on is not open in Pro, I can't delete it unless I close all instances of Pro. This is even if I delete all variables referencing class objects that are part of arcpy.mp.ArcGISProject .

0 Kudos
Robert_LeClair
Esri Esteemed Contributor

Certainly Jack - happy to assist where I can.  Have you contacted Esri Support Services to see if they can assist you further?

0 Kudos
__JackCharde__
Regular Contributor

Hey Robert,

 

Apologies for the very delayed reply. I did not contact support, but I definitely should!

0 Kudos
CMorneau
Occasional Contributor

Hello Robert.  Your response on this post caught my attention.  Please see my related post from 05-14-2025, entitled Map Automation - Seeking Scripting Solution for Opening an APRX from Python IDLE.  For my particular project, I would challenge the notion that the "method has little value when run in a script outside of the application".  Maybe what I'm trying to do is somewhat obscure or uncommon, but for my organization it certainly does have value.  Regardless, I greatly appreciate your response on 03-20-2024.  It provides valuable insight regarding the issue I've encountered.

0 Kudos
Robert_LeClair
Esri Esteemed Contributor

Hello @CMorneau - the statement is my response was attributed to the "ENH-000140298 - Add a method to the arcpy.mp.ArcGISProject() object that will close the project and release locks held by a script" request I found within the "internals" and is not a statement that I would make.  Apologies if it came across that way as that was not my intent.  Please let me know if there's anything I may assist you with!