99999久久久久久亚洲,欧美人与禽猛交狂配,高清日韩av在线影院,一个人在线高清免费观看,啦啦啦在线视频免费观看www

熱線電話:13121318867

登錄
首頁精彩閱讀再見 Pycharm,這款開箱即用的輕量級神器你值得擁有【CDA內(nèi)容分享】
再見 Pycharm,這款開箱即用的輕量級神器你值得擁有【CDA內(nèi)容分享】
2021-12-06
收藏

今天CDA給大家分享的內(nèi)容:開箱即用的輕量級神器

作者:豆豆

來源:Python 技術(shù)

如果你問我最好用的 IDE 是什么,那我肯定會毫不猶豫的告訴你 Pycharm。畢竟 jetbrains 出品必屬精品。

但對于很多初學(xué)者來講,Pycharm 顯得略笨重,很多功能點也不夠簡單易上手,對電腦的配置要求也會稍微高一些。導(dǎo)致很多人被 IDE 折磨的抓狂,今天派森醬就給大家介紹一款簡單、易上手、面向初學(xué)者的的輕量級 IDE - Thonny。

安裝

Thonny 是由愛沙尼亞的 Tartu 大學(xué)開發(fā),非常適合初學(xué)者的一款輕量級 IDE。

該 IDE 目前支持三大主流操作系統(tǒng),可以從官網(wǎng)直接下載安裝。

https://thonny.org/ 

打開上面的網(wǎng)址之后,選擇對應(yīng)的操作系統(tǒng)直接下載即可。

再見 Pycharm,這款開箱即用的輕量級神器你值得擁有

當(dāng)你安裝完畢滿心歡喜的啟動應(yīng)用之后,你會發(fā)現(xiàn)居然還可以選擇語言,其實對于編程類的 IDE 還是英文看起來會比較舒服,但這次我想試一下中文,看看支持程度到底怎么樣。

再見 Pycharm,這款開箱即用的輕量級神器你值得擁有

初體驗

打開軟件之后,你會發(fā)現(xiàn)界面是如此的簡潔,這對于初學(xué)者是極其友好的,不會被過多的分散精力,把主要精力放在代碼上即可。

再見 Pycharm,這款開箱即用的輕量級神器你值得擁有

默認(rèn)界面分為上下兩個部分,上面是代碼區(qū),下面是終端區(qū)。

嗯,先整個 Hello World 試一下。

再見 Pycharm,這款開箱即用的輕量級神器你值得擁有

可以看到,在終端 Hello World 已經(jīng)被正確的輸出來了,至此,環(huán)境是跑通了。

不知道你注意到?jīng)]有,從始至終我們都沒有安裝過 Python,也沒有配置過 Python 解釋器,事實上 Thonny 是自帶了 Python 解釋器了,真正做到了開箱即用。

當(dāng)然,你也可以配置自己的解釋器,在菜單欄點擊“運行” -> “選擇解釋器”來更改默認(rèn)的解釋器。

視圖

我們所寫的程序中通常都會定義非常多的變量,如果可以清楚的看到程序運行過程中變量的值那簡直不要太爽。

你可以通過菜單欄的「視圖」來勾選不同的選項來顯示和關(guān)閉不同的視圖窗口,通常情況下可以把變量和堆勾選上,這對于調(diào)試程序非常有幫助。尤其是對于初學(xué)者來講,可以非常直觀的看到變量的值。

再見 Pycharm,這款開箱即用的輕量級神器你值得擁有
再見 Pycharm,這款開箱即用的輕量級神器你值得擁有

所見即所得,這點 Thonny 的體驗超好。

調(diào)試

對于很多初學(xué)者來講,函數(shù)之間的調(diào)用是很難理解的,尤其是涉及到遞歸函數(shù)時。但這塊 Thonny 做的非常好。

打開你想調(diào)試的程序,甚至都不需要設(shè)置斷點,直接以 debug 模式運行即可,工具會自動的按照程序步驟來運行,而且涉及到函數(shù)時,會自動彈出一個新的窗口來顯示運行情況,就連運行過程中變量的值都會在新窗口一并顯示,而這一點也不會影響舊窗口。

尤其是涉及到多層函數(shù)嵌套,尤其是遞歸函數(shù),每調(diào)用一次嵌套函數(shù)就會打開一個新的窗口來顯示,這對于初學(xué)者來說簡直是莫大的福利啊。

再見 Pycharm,這款開箱即用的輕量級神器你值得擁有

堆棧

要想理解 Python 的內(nèi)存模型就離不開堆棧,而 Thonny 做到了將堆??梢暬?/span>

在代碼區(qū)輸入以下代碼。

a = [1, 2, 3, 4]
b = a
b.append(5) print(a) print(b)

運行之后你會在變量視圖發(fā)現(xiàn)變量 a 和 b 居然都指向了同一塊內(nèi)存地址,這也就解釋了為啥改變 b 之后 a 的值也一起跟著改變了。

再見 Pycharm,這款開箱即用的輕量級神器你值得擁有

錯誤提示

在錯誤提示這塊 Thonny 同樣有代碼高亮提示,當(dāng)你的代碼有很明顯的語法錯誤時,Thonny 會將整行代碼高亮來提示你此行代碼有錯誤。

與此同時,Thonny 還會給出明確的整改建議。

再見 Pycharm,這款開箱即用的輕量級神器你值得擁有

總結(jié)

今天給大家介紹了 Thonny 的基本使用,這是一款面向初學(xué)者的輕量級 IDE,可以讓初學(xué)者更好更快的入門上手 Python,而不致于在環(huán)境上浪費過多的時間。

關(guān)于 Thonny 的使用大家還有什么技巧可以在評論區(qū)交流哦~

數(shù)據(jù)分析咨詢請掃描二維碼

若不方便掃碼,搜微信號:CDAshujufenxi

數(shù)據(jù)分析師資訊
更多

OK
客服在線
立即咨詢
客服在線
立即咨詢
') } function initGt() { var handler = function (captchaObj) { captchaObj.appendTo('#captcha'); captchaObj.onReady(function () { $("#wait").hide(); }).onSuccess(function(){ $('.getcheckcode').removeClass('dis'); $('.getcheckcode').trigger('click'); }); window.captchaObj = captchaObj; }; $('#captcha').show(); $.ajax({ url: "/login/gtstart?t=" + (new Date()).getTime(), // 加隨機數(shù)防止緩存 type: "get", dataType: "json", success: function (data) { $('#text').hide(); $('#wait').show(); // 調(diào)用 initGeetest 進(jìn)行初始化 // 參數(shù)1:配置參數(shù) // 參數(shù)2:回調(diào),回調(diào)的第一個參數(shù)驗證碼對象,之后可以使用它調(diào)用相應(yīng)的接口 initGeetest({ // 以下 4 個配置參數(shù)為必須,不能缺少 gt: data.gt, challenge: data.challenge, offline: !data.success, // 表示用戶后臺檢測極驗服務(wù)器是否宕機 new_captcha: data.new_captcha, // 用于宕機時表示是新驗證碼的宕機 product: "float", // 產(chǎn)品形式,包括:float,popup width: "280px", https: true // 更多配置參數(shù)說明請參見:http://docs.geetest.com/install/client/web-front/ }, handler); } }); } function codeCutdown() { if(_wait == 0){ //倒計時完成 $(".getcheckcode").removeClass('dis').html("重新獲取"); }else{ $(".getcheckcode").addClass('dis').html("重新獲取("+_wait+"s)"); _wait--; setTimeout(function () { codeCutdown(); },1000); } } function inputValidate(ele,telInput) { var oInput = ele; var inputVal = oInput.val(); var oType = ele.attr('data-type'); var oEtag = $('#etag').val(); var oErr = oInput.closest('.form_box').next('.err_txt'); var empTxt = '請輸入'+oInput.attr('placeholder')+'!'; var errTxt = '請輸入正確的'+oInput.attr('placeholder')+'!'; var pattern; if(inputVal==""){ if(!telInput){ errFun(oErr,empTxt); } return false; }else { switch (oType){ case 'login_mobile': pattern = /^1[3456789]\d{9}$/; if(inputVal.length==11) { $.ajax({ url: '/login/checkmobile', type: "post", dataType: "json", data: { mobile: inputVal, etag: oEtag, page_ur: window.location.href, page_referer: document.referrer }, success: function (data) { } }); } break; case 'login_yzm': pattern = /^\d{6}$/; break; } if(oType=='login_mobile'){ } if(!!validateFun(pattern,inputVal)){ errFun(oErr,'') if(telInput){ $('.getcheckcode').removeClass('dis'); } }else { if(!telInput) { errFun(oErr, errTxt); }else { $('.getcheckcode').addClass('dis'); } return false; } } return true; } function errFun(obj,msg) { obj.html(msg); if(msg==''){ $('.login_submit').removeClass('dis'); }else { $('.login_submit').addClass('dis'); } } function validateFun(pat,val) { return pat.test(val); }