91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

python函數中如何將變量名轉換成字符串

發布時間:2020-07-28 09:56:13 來源:億速云 閱讀:763 作者:小豬 欄目:開發技術

這篇文章主要為大家展示了python函數中如何將變量名轉換成字符串,內容簡而易懂,希望大家可以學習一下,學習完之后肯定會有收獲的,下面讓小編帶大家一起來看看吧。

考慮到在日常中,常常需要對模型指標輸出,但涉及多個模型的時候,需要對其有標示輸出,故需要將模型變量名轉換成字符串。

看到的基本方法有兩種:

一、方法層面:

方法1(函數內推薦):

def namestr(obj, namespace):
 return [name for name in namespace if namespace[name] is obj]
print(namestr(lr_origin,globals()),'\n',
namestr(lr_origin,globals())[0])

輸出:

‘lr_origin'

方法2:

import inspect, re
def varname(p):
 for line in inspect.getframeinfo(inspect.currentframe().f_back)[3]:
 m = re.search(r'\bvarname\s*\(\s*([A-Za-z_][A-Za-z0-9_]*)\s*\)', line)
 if m:
 return m.group(1)
varname(lr_origin)

輸出:

'lr_origin'

二、示例

采用方法1

def small_feature_model(model,X_train=X_train,y_train=y_train,X_test=X_test, y_test=y_test):
 pca = PCA(n_components=150,random_state=0,whiten=True)
 pipeline = Pipeline([('scale',StandardScaler()),('pca',pca)])
 processing = pipeline.fit(X_train)
 X_train = processing.transform(X_train)
 X_test = processing.transform(X_test)
 model.fit(X_train, y_train)
 y_pred = model.predict(X_test)
# print(namestr(model,globals()))
 print('**small-%s的準確率**: %.3f' %(namestr(model,globals())[0],accuracy_score(y_pred=y_pred, y_true=y_test)))
 small_feature_model(svm_origin)

輸出

['svm_origin']
**small-svm_origin的準確率**: 0.789

for model in [svm_origin, svm_rbf, lr_origin]:
small_feature_model(model)

輸出

**small-svm_origin的準確率**: 0.789
**small-svm_rbf的準確率**: 0.811
**small-lr_origin的準確率**: 0.835

采用方法2

def small_feature_model(model,X_train=X_train,y_train=y_train,X_test=X_test, y_test=y_test):
 pca = PCA(n_components=150,random_state=0,whiten=True)
 pipeline = Pipeline([('scale',StandardScaler()),('pca',pca)])
 processing = pipeline.fit(X_train)
 X_train = processing.transform(X_train)
 X_test = processing.transform(X_test)
 model.fit(X_train, y_train)
 y_pred = model.predict(X_test)
# print(namestr(model,globals()))
 print('**small-%s的準確率**: %.3f' %(varname(model),accuracy_score(y_pred=y_pred, y_true=y_test)))
 small_feature_model(svm_origin)

輸出

**small-model的準確率**: 0.789

for model in [svm_origin, svm_rbf, lr_origin]:
small_feature_model(model)

輸出

**small-model的準確率**: 0.789
**small-model的準確率**: 0.811
**small-model的準確率**: 0.835

補充知識:一個python實現翻轉字符串的函數

實現字符串翻轉的函數(python)

string = 'abcdef'
def demo1(string):
 if len(string) <= 1:
  return string
 return demo1(string[1:]) +string[0]
print(demo1(string))

中間用到了遞歸和切片不知道效率如何

以上就是關于python函數中如何將變量名轉換成字符串的內容,如果你們有學習到知識或者技能,可以把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

延安市| 平远县| 安吉县| 安福县| 综艺| 汉寿县| 辽阳市| 湘潭县| 松江区| 余姚市| 桑植县| 开远市| 栾川县| 浙江省| 武山县| 新竹县| 简阳市| 漳浦县| 岑溪市| 贵阳市| 抚州市| 新河县| 巴彦县| 新野县| 高台县| 密云县| 清苑县| 葫芦岛市| 鄂尔多斯市| 巴东县| 蓬莱市| 华坪县| 开阳县| 昂仁县| 保定市| 莱西市| 大同县| 远安县| 永胜县| 金溪县| 辉南县|