I am trying to test some of my 2.7 python scripts on 3.6 python and i noticed a huge difference on amount of time it takes to run the FeatureClassToFeatureClass_conversion process. so with 3.6 python the process took 18 min 5 secs, with 2.6 python it took only 8 seconds. Does anyone know why the it take much longer in 3.6 Python?
This is what i am using, there is more fields than this i just removed a lot of them.
PT1 = "C:/Temp/Scratchworkspace.gdb/Drain"
def Layers15(PT1):
    FieldMapString = "" \
                + """PIN "PIN" true true false 13 Text 0 0 ,First,#,""" + PT1 + """,Pin,-1,-1;"""\
                + """ACRES "ACRES" true true false 4 Double 0 0  ,First,#,""" + PT1+ """,ACRES,-1,-1;"""\
                + """Instrument "Instrument" true true false 10 Text 0 0 ,First,#,""" + PT1 + """,Instrument,-1,-1;"""\
                + """SiteAddres "SiteAddres" true true false 106 Text 0 0 ,First,#,""" + PT1 + """,SiteAddres,-1,-1;"""\
                + """SiteCity "SiteCity" true true false 32 Text 0 0 ,First,#,""" + PT1 + """,SiteCity,-1,-1;"""\
                + """SiteZip "SiteZip" true true false 10 Text 0 0 ,First,#,""" + PT1 + """,SiteZip,-1,-1;"""\
                + """SubName "SubName" true true false 20 Text 0 0 ,First,#,""" + PT1 + """,SubName,-1,-1;"""\       
                            
    fieldmappings = arcpy.FieldMappings()
    fieldmappings.loadFromString(FieldMapString)
    return fieldmappings
def main(args=None):
        if args is None:
                args = sys.argv
# Process: Feature Class to Feature Class
arcpy.FeatureClassToFeatureClass_conversion(PT1, "C:/Temp/Scratchworkspace.gdb", "PT_ALL","", Layers15(PT1),"")the arcpy and arcgisscripting and all the esri stuff in Pro is different, so when you call FeatureClassToFeatureClass, there is an arcmap and an ArcGIS pro version. If you will notice your pure python stuff in your code example very limited...
Try testing it yourself if you have an appropriate python ide that used line magics (ie IPython in Spyder etc)
def tester():
    PT1 = 'HELLO'
    FieldMapString = '''
    PIN "PIN" true true false 13 Text 0 0 ,First,#, {0}, Pin,-1,-1;
    ACRES "ACRES" true true false 4 Double 0 0  ,First,#, {0}, ACRES,-1,-1;
    Instrument "Instrument" true true false 10 Text 0 0 ,First,#, {0}, Instrument,-1,-1;
    SiteAddres "SiteAddres" true true false 106 Text 0 0 ,First,#, {0}, SiteAddres,-1,-1;
    SiteCity "SiteCity" true true false 32 Text 0 0 ,First,#, {0}, SiteCity,-1,-1;
    SiteZip "SiteZip" true true false 10 Text 0 0 ,First,#, {0}, SiteZip,-1,-1;
    SubName "SubName" true true false 20 Text 0 0 ,First,#, {0}, SubName,-1,-1;
    '''
    FieldMapString.format(PT1)
    return
# ----- timing section
tester()
%timeit tester()
2.36 µs ± 194 ns per loop (mean ± std. dev. of 7 runs, 100000 loops each)
# ---- that is on my laptop, haven't tested on the desktopSo if yours is several orders of magnitude faster than 2ish microseconds then you can blame python 3... otherwise file a case with esri about the slowness of fc2fc with field mapping
ok i think i understand. so i tired to run what you posted to test but i am getting invalid syntax on line with %timeit Tester()
which means you don't have 'line magics' so you have an older IDE (try spyder, you will have to replace timing stuff with whatever you use)
You answered Dan's question about the field mapping being necessary, but did you try copying without using a field mapping? In terms of isolating the issue, it is important to know whether the field mapping is contributing to the problem or if it something else.
I upgrade to Pro 2.3 this morning and now i am getting this error on line 81 and i didn't change the script at all.
RuntimeError: ERROR 999999: Something unexpected caused the tool to fail. Contact Esri Technical Support (http://esriurl.com/support) to Report a Bug, and refer to the error help for potential solutions or workarounds.
import sys, arcpy, os, fnmatch
from datetime import datetime as d
startTime = d.now()
start_time = time.time()
# Local variables:
print ('Started')
arcpy.env.overwriteOutput = True
arcpy.env.workspace = "C:/Temp/Scratchworkspace.gdb"
arcpy.env.qualifiedFieldNames = False
arcpy.env.preserveGlobalIds = True
PT1 = "C:/Temp/Scratchworkspace.gdb/Drain"
FieldMapString = '''
DXF_TEXT "DXF_TEXT" true true false 11 Text 0 0 ,First,#, {0}, ACRES,-1,-1;
ACCOUNT "ACCOUNT" true true false 11 Text 0 0 ,First,#, {0}, ACCOUNT,-1,-1;
PIN "PIN" true true false 13 Text 0 0 ,First,#, {0}, PIN,-1,-1;
ACRES "ACRES" true true false 4 Double 0 0  ,First,#, {0}, ACRES,-1,-1;
Instrument "Instrument" true true false 10 Text 0 0 ,First,#, {0}, Instrument,-1,-1;
SiteAddres "SiteAddres" true true false 106 Text 0 0 ,First,#, {0}, SiteAddres,-1,-1;
SiteCity "SiteCity" true true false 32 Text 0 0 ,First,#, {0}, SiteZip,-1,-1;
SiteZip "SiteZip" true true false 10 Text 0 0 ,First,#, {0}, SiteZip,-1,-1;
'''
#print(FieldMapString.format(PT1))
def Layers15(PT1, FieldMapString):
    """pass the variable and the constant into
    the function
    """
    fieldmappings = arcpy.FieldMappings()
    fieldmappings.loadFromString(FieldMapString)
    return fieldmappings
def main(args=None):
        if args is None:
                args = sys.argv
# Process: Feature Class to Feature Class
arcpy.FeatureClassToFeatureClass_conversion(PT1, "C:/Temp/Scratchworkspace.gdb", "PT_ALL","", Layers15(PT1, FieldMapString),"")
print ("Finished")
print ('(Elapsed time: ' + str(d.now() - startTime)[:-3] + ')')
try:
    print ('(Elapsed time: ' + str(d.now() - startTime)[:-3] + ')')
except Exception as e:
    # If an error occurred, print line number and error message
    import traceback, sys
    tb = sys.exc_info()[2]
    print ("Line %i" % tb.tb_lineno)
    print (e.message)
Over the last 10 years since python 2.x, python 3 has had a number of changes to the datetime module and dates in general
datetime — Basic date and time types — Python 3.7.2 documentation
you should check out some of the changes and/or new features
