基礎知識:索引和分片

索引

對於一個有序序列,能夠經過索引的方法來訪問對應位置的值。字符串即是一個有序序列的例子,Python使用 [] 來對有序序列進行索引。
  
 
  
Python中索引是從  開始的,因此索引  對應與序列的第  個元素。爲了獲得第  個元素,須要使用索引值  。
00154
  
 
   
  
除了正向索引,Python還引入了負索引值的用法,即從後向前開始計數,例如,索引  表示倒數第  個元素:
-22
 
單個索引大於等於字符串的長度時,會報錯:
 
  

 

分片

分片用來從序列中提取出想要的子序列,其用法爲:ui

var[lower:upper:step]

其範圍包括 lower ,但不包括 upper ,即 [lower, upper) step 表示取值間隔大小,若是沒有默認爲1spa

   

   

 
   
分片中包含的元素的個數爲  。
3-1=2
也能夠使用負索引來指定分片的範圍:
包括索引 1 可是不包括索引 -2 。

lower和upper能夠省略,省略lower意味着從開頭開始分片,省略upper意味着一直分片到結尾。3d

   

每隔兩個取一個值:
  
當step的值爲負時,省略lower意味着從結尾開始分片,省略upper意味着一直分片到開頭。
  
 
   
當給定的upper超出字符串的長度(注意:由於不包含upper,因此能夠等於)時,Python並不會報錯,不過只會計算到結尾。
  
 
   
 
   
 
    
   

使用「0」做爲索引開頭的緣由

使用[low, up)形式的緣由

假設須要表示字符串 hello 中的內部子串 el :
方式 [low, up) (low, up] (lower, upper) [lower, upper]
表示 [1,3) (0,2] (0,3) [1,2]
序列長度 up - low up - low up - low - 1 up - low + 1

對長度來講,前兩種方式比較好,由於不須要煩人的加一減一。
如今只考慮前兩種方法,假設要表示字符串中的從頭開始的子串:
hellohel
方式 [low, up) (low, up]
表示 [0,3) (-1,2]
序列長度 up - low up - low

第二種表示方法從開始,不是很好,因此選擇使用第一種的形式。
-1[low, up)
 
    
   

使用0-base的形式

 
Just too beautiful to ignore.
----Guido van Rossum
 

兩種簡單的狀況:code

  • 從頭開始的n個元素;blog

    • 使用0-base:[0, n)
    • 使用1-base:[1, n+1)
  • i+1個元素到第i+n個元素。索引

    • 使用0-base:[i, n+i)
    • 使用1-base:[i+1, n+i+1)

1-base有個+1部分,因此不推薦。字符串

綜合這兩種緣由,Python使用0-base的方法來進行索引。table

相關文章
相關標籤/搜索