美文网首页
python索引和分片

python索引和分片

作者: 脏脏包盛 | 来源:发表于2017-12-16 14:17 被阅读0次

索引

s = "hello world"
s[0]
s[1]
s[-2]

分片

分片用来从序列中提取出想要的子序列,其用法为:

var[lower:upper:step]

其范围包括 lower ,但不包括 upper ,即 [lower, upper), step 表示取值间隔大小,如果没有默认为1。

s = 'hello world'
s[1:3]                             #'el'
s[1:-2]                            #'ello wor'        包括1不包括-2
s[:3]                               #'hel'                省略lower,不包括3
s[3:]                               #'lo world'        省略upper,包括3
s[:]
s[::2]                              #'hlowrd'
s[::-2]                             #'drwolh'           当step的值为负时,省略lower意味着从结尾开始分片,
                                                       #省略upper意味着一直分片到开头。

使用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

对长度来说,前两种方式比较好,因为不需要烦人的加一减一。
现在只考虑前两种方法,假设要表示字符串hello中的从头开始的子串hel:

方式 [low, up) (low, up]
表示 [0,3) (-1,2]
序列长度 up - low up - low

第二种表示方法从-1开始,不是很好,所以选择使用第一种[low, up)的形式。

使用0-base的形式

两种简单的情况:

从头开始的n个元素;

  • 使用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的方法来进行索引。

相关文章

  • python索引和分片

    索引 分片 分片用来从序列中提取出想要的子序列,其用法为: var[lower:upper:step] 其范围包括...

  • 学习python分片

    序列和索引 既然谈到分片,就脱离不了序列和索引这些概念。什么是序列呢? 在Python中,最基本的数据结构是序列(...

  • 搜索引擎ElasticSearch之(2)、索引管理

    1、索引管理 1.1、索引创建 创建索引主要设置主分片及副分片数量。索引创建后,主分片数不能更改,可以修改副本分片...

  • ElasticSearch-索引原理

    索引分片 索引分片-水平扩展: 索引分片-应对故障: 数据路由 路由策略: 1、 路由公式:shard = has...

  • 索引和分片

    索引 对于一个有序序列,可以通过索引的方法来访问对应位置的值。字符串便是一个有序序列的例子,Python使用 []...

  • 配置高性能 Elasticsearch 集群的 9 个小贴士

    小贴士1:规划索引、分片 以及集群增长情况 ES使得创建大量索引和超大量分片非常地容易,但更重要的是理解每个索引和...

  • 常用Elasticsearch API接口

    查看节点信息 查看索引信息 新增索引 查看新增的索引: green:所有的主分片和副本分片都已分配。你的集群是10...

  • 2.Python-序列,索引和分片

    序列 常见序列类型包括字符串(普通字符串和unicode字符串),列表和元组.所谓序列,即成员有序排列,可通过下标...

  • ElasticSearch(七):分布式特性

    一 分片和副本 分片特性分片存储部分数据,可以分布任意节点上;分片在创建索引时指定且不许更改,默认为5个;分片有主...

  • elasticsearch 内部存储执行机制

    新建、索引和删除单个文档 以下是在主副分片和任何副本分片上面成功新建,索引和删除文档所需要的步骤顺序: 客户端向 ...

网友评论

      本文标题:python索引和分片

      本文链接:https://www.haomeiwen.com/subject/bfuswxtx.html