• <fieldset id="8imwq"><menu id="8imwq"></menu></fieldset>
  • <bdo id="8imwq"><input id="8imwq"></input></bdo>
    最新文章專題視頻專題問答1問答10問答100問答1000問答2000關(guān)鍵字專題1關(guān)鍵字專題50關(guān)鍵字專題500關(guān)鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關(guān)鍵字專題關(guān)鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
    問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
    當前位置: 首頁 - 科技 - 知識百科 - 正文

    Python的Django框架中從url中捕捉文本的方法

    來源:懂視網(wǎng) 責編:小采 時間:2020-11-27 14:41:55
    文檔

    Python的Django框架中從url中捕捉文本的方法

    Python的Django框架中從url中捕捉文本的方法:每個被捕獲的參數(shù)將被作為純Python字符串來發(fā)送,而不管正則表達式中的格式。 舉個例子,在這行URLConf中: (r'^articles/(?P\d{4})/$', views.year_archive), 盡管 \d{4} 將只匹配整數(shù)的字符串,但是參數(shù) year 是作為字符串傳至 view
    推薦度:
    導(dǎo)讀Python的Django框架中從url中捕捉文本的方法:每個被捕獲的參數(shù)將被作為純Python字符串來發(fā)送,而不管正則表達式中的格式。 舉個例子,在這行URLConf中: (r'^articles/(?P\d{4})/$', views.year_archive), 盡管 \d{4} 將只匹配整數(shù)的字符串,但是參數(shù) year 是作為字符串傳至 view

    每個被捕獲的參數(shù)將被作為純Python字符串來發(fā)送,而不管正則表達式中的格式。 舉個例子,在這行URLConf中:

    (r'^articles/(?Pd{4})/$', views.year_archive),
    
    

    盡管 d{4} 將只匹配整數(shù)的字符串,但是參數(shù) year 是作為字符串傳至 views.year_archive() 的,而不是整型。

    當你在寫視圖代碼時記住這點很重要,許多Python內(nèi)建的方法對于接受的對象的類型很講究。 許多內(nèi)置Python函數(shù)是挑剔的(這是理所當然的)只接受特定類型的對象。 一個典型的的錯誤就是用字符串值而不是整數(shù)值來創(chuàng)建 datetime.date 對象:

    >>> import datetime
    >>> datetime.date('1993', '7', '9')
    Traceback (most recent call last):
     ...
    TypeError: an integer is required
    >>> datetime.date(1993, 7, 9)
    datetime.date(1993, 7, 9)
    
    

    回到URLconf和視圖處,錯誤看起來很可能是這樣:

    # urls.py
    
    from django.conf.urls.defaults import *
    from mysite import views
    
    urlpatterns = patterns('',
     (r'^articles/(d{4})/(d{2})/(d{2})/$', views.day_archive),
    )
    
    # views.py
    
    import datetime
    
    def day_archive(request, year, month, day):
     # The following statement raises a TypeError!
     date = datetime.date(year, month, day)
    
    

    因此, day_archive() 應(yīng)該這樣寫才是正確的:

    def day_archive(request, year, month, day):
     date = datetime.date(int(year), int(month), int(day))
    
    

    注意,當你傳遞了一個并不完全包含數(shù)字的字符串時, int() 會拋出 ValueError 的異常,不過我們已經(jīng)避免了這個錯誤,因為在URLconf的正則表達式中已經(jīng)確保只有包含數(shù)字的字符串才會傳到這個視圖函數(shù)中。
    決定URLconf搜索的東西

    當一個請求進來時,Django試著將請求的URL作為一個普通Python字符串進行URLconf模式匹配(而不是作為一個Unicode字符串)。 這并不包括 GET 或 POST 參數(shù)或域名。 它也不包括第一個斜杠,因為每個URL必定有一個斜杠。

    例如,在向 http://www.example.com/myapp/ 的請求中,Django將試著去匹配 myapp/ 。在向 http://www.example.com/myapp/?page=3 的請求中,Django同樣會去匹配 myapp/ 。

    在解析URLconf時,請求方法(例如, POST , GET , HEAD )并 不會 被考慮。 換而言之,對于相同的URL的所有請求方法將被導(dǎo)向到相同的函數(shù)中。 因此根據(jù)請求方法來處理分支是視圖函數(shù)的責任。

    聲明:本網(wǎng)頁內(nèi)容旨在傳播知識,若有侵權(quán)等問題請及時與本網(wǎng)聯(lián)系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

    文檔

    Python的Django框架中從url中捕捉文本的方法

    Python的Django框架中從url中捕捉文本的方法:每個被捕獲的參數(shù)將被作為純Python字符串來發(fā)送,而不管正則表達式中的格式。 舉個例子,在這行URLConf中: (r'^articles/(?P\d{4})/$', views.year_archive), 盡管 \d{4} 將只匹配整數(shù)的字符串,但是參數(shù) year 是作為字符串傳至 view
    推薦度:
    標簽: 的方法 捕捉 文本
    • 熱門焦點

    最新推薦

    猜你喜歡

    熱門推薦

    專題
    Top
    主站蜘蛛池模板: 中文字幕精品视频在线| 国产精品一区二区av| 亚洲精品视频免费| 精品国产_亚洲人成在线高清| 亚洲国产精品乱码一区二区| 精品人妻少妇一区二区三区不卡| 日韩一级精品视频在线观看| 国产精品久久久久久吹潮| 亚洲精品无码专区久久同性男| 国产精品免费久久久久久久久| 97久久综合精品久久久综合| 亚洲精品自产拍在线观看| 国内精品久久久久久久影视麻豆| 好吊妞视频精品| 国产精品99久久免费观看| 亚洲一区二区三区国产精品| 无码乱码观看精品久久| 欧美精品91欧美日韩操| 国产亚洲精品不卡在线| 99视频在线精品国自产拍亚瑟| 国内精品久久人妻互换| 日产精品一线二线三线芒果| 综合人妻久久一区二区精品| 四虎成人精品国产永久免费无码| 久久国产综合精品五月天| 国内精品欧美久久精品| 国产一区二区三区欧美精品| 国产高清在线精品一区二区三区| 777欧美午夜精品影院| 亚洲精品免费视频| 亚洲国产精品国自产电影| 久久九九亚洲精品| 欧美成人精品一级高清片| 久热这里只精品99re8久| 免费精品99久久国产综合精品| 久久九九亚洲精品| 9久热这里只有精品| 国产精品99久久不卡| 国精品产露脸自拍| 人妻少妇精品系列| 亚洲无码精品浪潮|