pathlib seems to be the preferred method for working with system paths in Python 3. We've started using it in place of `os.path` in our office recently and really like it. However, we've run into problems with using it with arcpy. For example:
workspace = pathlib.Path('C:\some path') \ 'anotherfolder' \ 'connection.sde'
Throws this error: "RuntimeError: Object: Error in accessing environment <workspace>"
To work around this, we end up wrapping all of our Path object with str(). For example:
workspace = str(pathlib.Path('C:\some path') \ 'anotherfolder' \ 'connection.sde')
It would be great if arcpy (Pro version) handled these Path objects natively!
This would be much appreciated. Going into Python 3 we want to make good use of the new stuff like Pathlib and f-strings.
When using a path created from pathlib, arcpy.da.SearchCursor() returns
RuntimeError: 'in_table' is not a table or a featureclass
If the path is formatted with str() it works fine. Hopefully there's a way the cursor, and anything else that's relevant, can accept native objects from pathlib. Please see this relevant post Using pathlib with SearchCursor
@BlakeTerhune - having read you other post earlier, what is the advantage of pathlib?
@JoeBorgione I found a nice summary here. Also see the official documentation that compares the path related tools from os module.
Working with pathlib paths is a much nicer experience than plain strings and os.path anipulations. We are considering this work, but do estimate this to be a larger change, because of the number of different places that we currently explicitly pass only strings and expect the objects to be strings without further inspection.
Thank you for the consideration @ShaunWalbridge! :smiling_face_with_smiling_eyes:
You must be a registered user to add a comment. If you've already registered, sign in. Otherwise, register and sign in.