Python包基础知识

时间:2017-07-07 10:28:09

标签: python package

我有一个名为1) First, we lock GE_SANDBX.A for access, we lock GE_SANDBX.B for access, we lock DP_TAB.PARTY_ACCT_HIST for access, we lock DP_TAB.GE_PI for access, and we lock DP_TAB.ACCT for access. 2) Next, we do an all-AMPs RETRIEVE step from DP_TAB.ACCT by way of an all-rows scan with a condition of ( "DP_TAB.ACCT.DATA_SOURCE_TYPE_CD = 'ILL '") into Spool 3 (all_amps), which is built locally on the AMPs. The size of Spool 3 is estimated with no confidence to be 9,834,342 rows ( 344,201,970 bytes). The estimated time for this step is 2.18 seconds. 3) We do an all-AMPs JOIN step from Spool 3 (Last Use) by way of a RowHash match scan, which is joined to DP_TAB.PARTY_ACCT_HIST by way of a RowHash match scan with no residual conditions. Spool 3 and DP_TAB.PARTY_ACCT_HIST are joined using a merge join, with a join condition of ("Acct_Id = DP_TAB.PARTY_ACCT_HIST.ACCT_ID"). The result goes into Spool 4 (all_amps), which is redistributed by the hash code of (DP_TAB.ACCT.Acct_Num) to all AMPs. Then we do a SORT to order Spool 4 by row hash. The size of Spool 4 is estimated with no confidence to be 13,915,265 rows (487,034,275 bytes). The estimated time for this step is 0.98 seconds. 4) We execute the following steps in parallel. 1) We do an all-AMPs JOIN step from GE_SANDBX.B by way of a RowHash match scan with no residual conditions, which is joined to Spool 4 (Last Use) by way of a RowHash match scan. GE_SANDBX.B and Spool 4 are joined using a merge join, with a join condition of ("GE_SANDBX.B.ACACCNO = Acct_Num"). The result goes into Spool 5 (all_amps) fanned out into 18 hash join partitions, which is redistributed by the hash code of (GE_SANDBX.B.ACCUSNO) to all AMPs. The size of Spool 5 is estimated with no confidence to be 13,915,265 rows (2,657,815,615 bytes). The estimated time for this step is 1.33 seconds. 2) We do an all-AMPs RETRIEVE step from GE_SANDBX.A by way of an all-rows scan with no residual conditions into Spool 6 (all_amps) fanned out into 18 hash join partitions, which is redistributed by the hash code of (GE_SANDBX.A.ICCUSNO) to all AMPs. The size of Spool 6 is estimated with high confidence to be 12,169,929 rows (5,427,788,334 bytes). The estimated time for this step is 52.24 seconds. 3) We do an all-AMPs RETRIEVE step from DP_TAB.GE_PI by way of an all-rows scan with a condition of ( "(DP_TAB.GE_PI.DSTC <> 'BSCRM') AND (DP_TAB.GE_PI.DATA_SOURCE_TYPE_CD <> 'SCRM')") into Spool 7 (all_amps), which is built locally on the AMPs. The size of Spool 7 is estimated with low confidence to be 161,829 rows (19,419,480 bytes). The estimated time for this step is 1.97 seconds. 5) We do an all-AMPs JOIN step from Spool 5 (Last Use) by way of an all-rows scan, which is joined to Spool 6 (Last Use) by way of an all-rows scan. Spool 5 and Spool 6 are joined using a hash join of 18 partitions, with a join condition of ("ICCUSNO = ACCUSNO"). The result goes into Spool 8 (all_amps), which is redistributed by the hash code of (DP_TAB.PARTY_ACCT_HIST.PARTY_ID, TRANSLATE((GE_SANDBX.A.ICIDTY )USING LATIN_TO_UNICODE)(VARCHAR(255), CHARACTER SET UNICODE, NOT CASESPECIFIC)) to all AMPs. The size of Spool 8 is estimated with no confidence to be 15,972,616 rows (8,593,267,408 bytes). The estimated time for this step is 4.37 seconds. 6) We do an all-AMPs JOIN step from Spool 7 (Last Use) by way of an all-rows scan, which is joined to Spool 8 (Last Use) by way of an all-rows scan. Spool 7 and Spool 8 are right outer joined using a single partition hash join, with condition(s) used for non-matching on right table ("NOT (ICIDTY IS NULL)"), with a join condition of ("(PARTY_ID = Party_Id) AND ((TRANSLATE((ICIDTY )USING LATIN_TO_UNICODE))= Party_Identification_Type_Cd)"). The result goes into Spool 2 (all_amps), which is built locally on the AMPs. The size of Spool 2 is estimated with no confidence to be 16,053,773 rows (10,306,522,266 bytes). The estimated time for this step is 2.11 seconds. 7) We do an all-AMPs STAT FUNCTION step from Spool 2 (Last Use) by way of an all-rows scan into Spool 13 (Last Use), which is redistributed by hash code to all AMPs. The result rows are put into Spool 11 (all_amps), which is built locally on the AMPs. The size is estimated with no confidence to be 16,053,773 rows ( 18,558,161,588 bytes). 8) We do an all-AMPs RETRIEVE step from Spool 11 (Last Use) by way of an all-rows scan with a condition of ("(Party_Identification_Num <> ICIDNO) AND (Field_10 = 1)") into Spool 16 (group_amps), which is built locally on the AMPs. The size of Spool 16 is estimated with no confidence to be 10,488,598 rows (10,404,689,216 bytes). The estimated time for this step is 2.20 seconds. 9) Finally, we send out an END TRANSACTION step to all AMPs involved in processing the request. -> The contents of Spool 16 are sent back to the user as the result of statement 1. 的python文件。 此文件包含少量test1.py和少量classes

我打算将其打包并分发,以便其他人可以通过functions命令使用它。 从其他帖子中,我了解了我们如何构建一个包。

问:当使用pip install命令在最终用户的代码中导入包时,

1。只需编写函数名称即可直接调用函数吗?

作为课程一部分的

2。方法最好由import <mypackage>调用,现在将如何调用它们?

2 个答案:

答案 0 :(得分:1)

这取决于您如何导入包。如果您将包导入为

import test1

您必须使用test1.function()调用所有类和函数。像test1.objectname.methodname()

这样的类方法

如果您使用

from test1 import *

您可以使用函数名称,但您的命名空间被所有函数名称污染。

您也可以使用

仅导入特定的功能或类
from test1 import function1, function2, class1, class2

用他们各自的名字打电话给他们。

最后,您可以使用import test1 as t1使其缩短一点,然后可以使用t1.function1()

调用函数

答案 1 :(得分:0)

函数将附加到包名称。例如:

import numpy
# Calling the square root function from numpy
val = 4
newVal = numpy.sqrt(val)

# You can also do this, but it is not recommended as it pollutes your name space 
from numpy import sqrt

# Now I can call sqrt directly
val = 4
newVal = sqrt(val)

类方法的工作方式类似。