首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Excel公式技巧22: 从字符串中提取指定长度的连续数字子串

本文给出了一种从可能包含若干个不同长度的数字的字符串中提取指定长度的数字的解决方案。在实际的工作表中,存在着许多此类需求,例如从字符串中获取6位数字账号。...在这里,将介绍两种解决方案,第一种是静态的,要提取的数字长度是固定的;第二种是动态的,允许长度变化。...由于解决方案的关键之处在于有效地测试所有长度为8个字符的子字符串,并验证其中的子字符串依次由1个非数字、6个数字和1个非数字组成。对于6个数字处于字符串的开头或结尾的情况,进行适当调整。...在获得了由子字符串中的每个单独字符组成的数组之后,需要查询每个字符组确定其第一个和最后一个字符是否为非数字字符,中间的六个字符是否为六个数字。...个字符中的第一个字符在字符串中的位置相对应,注意这8个字符中的第一个字符是非数字,所以需要向右移动一个位置,即想要得到的六位数数字的开始。

3.1K20

Python学习入门基础 — 第四章 列表、元组、字典、字符串变量使用、变量进阶

字符串 列表 元组 字典 在 Python 中,所有 非数字型变量 都支持以下特点: 都是一个 序列 sequence,也可以理解为 容器 取值 [] 遍历 for in 计算长度、最大/最小值...开发中,有特定的应用场景 用于存储 一串 信息,数据 之间使用 , 分隔 元组用 () 定义 元组的 索引 从 0 开始 索引 就是数据在 元组 中的位置编号 info_tuple = ("zhangsan...字符串 4.1 字符串的定义 字符串 就是 一串字符,是编程语言中表示文本的数据类型 在 Python 中可以使用 一对双引号 " 或者 一对单引号 ' 定义一个字符串 虽然可以使用 \" 或者 \'...可变和不可变类型 不可变类型,内存中的数据不允许被修改: 数字类型 int, bool, float, complex, long(2.x) 字符串 str 元组 tuple 可变类型,内存中的数据可以被修改...对新赋值的数据引用 哈希 (hash) Python 中内置有一个名字叫做 hash(o) 的函数 接收一个 不可变类型 的数据作为 参数 返回 结果是一个 整数 哈希 是一种 算法,其作用就是提取数据的

2.1K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    手撕Python之正则

    从字符串中进行内容的匹配,不管在那个位置,都可以进行目标的寻找 只会匹配一次数据(就是字符串里面第一个满足条件的一串字符) import re r=re.search('test','tdestabcdfgsdtest...将会匹配字符串'aaa1212bbb'中的'aaa' 后面紧跟着的第一个字符,也就是数字'1'。因此,r.group()将会输出'aaa1'。...''' \d的匹配操作 将字符串中的数字提取出来 import re print(re.findall('\d','abd6c123')) #['6', '1', '2', '3'] \D的匹配操作 将字符串中的非数字匹配提取出来...将会匹配字符串'aaa1212bbb'中的'aaa' 后面紧跟着的第一个字符,也就是数字'1'。因此,r.group()将会输出'aaa1'。 ''' #贪婪 r=re.match('aaa....#这样就会很麻烦的 对于数据小的我们还可以使用字符串中的replace进行替换操作 但是如果是数据比较大的我们就不是很方便进行数据的替换操作了 sub(正则表达式,新数据,修改的字符串,替换次数) 通过正则表达式对字符串进行批量的替换

    12210

    Python学习杂记_3_字符串操作的常用方法

    字符串操作 字符串是可以通过下标来进行取值的,但是由于字符串是不可变变量,不能通过下标来修改它的值(形式如 字符串[下标]),下标从0开始,最大下标值是字符串长度减1,即len(string)-1 Python...事实上,for循环是遍历字符串names里所有的元素,只是这细致的操作Python在幕后代劳了,我们看起来只是比对,输入的一串是不是存在于names的一串串里。...以下所有字符串的方法,它都不会修改原来字符串的值,都会产生一个新的字符串,因为字符串一旦定义了就是不可变的,是不可变的变量,可以定义其他的变量来获取。...name.capitalize())  # 首字母大写 print('Abcdef'.swapcase())  # 大小写反转 print(name.center(5, '*'))  # 50个*,把name放中间...“数字” 或 “英文字母” 或 “数字和英文字母”,返回布尔值 print('abA'.isalpha())  # 是否是英文字母,返回布尔值 print('122'.isdigit())  # 是否是数字

    50430

    python基础之数据类型与变量

    在python中所有数据都是围绕对象这个概念来构建的,对象包含一些基本的数据类型:数字,字符串,列表,元组,字典等 程序中存储的所有数据都是对象, 对象三个特性 • 身份:内存地址,可以用id()获取...2.2.2字符串 字符串str:它是一个有序的字符的集合,用于存储和表示基本的文本信息,‘’或“”或‘’‘ ’‘’中间包含的内容称之为字符串,包含在引号(单,双,三)里面,由一串字符组成 特性: 1....只能存放一个值 2.不可变 3.按照从左到右的顺序定义字符集合,下标从0开始顺序访问,有序 补充:   1.字符串的单引号和双引号都无法取消特殊字符的含义,如果想让引号内所有字符均取消特殊意义,在引号前面加...r,如name=r'l\thf'   2.unicode字符串与r连用必需在r前面,如name=ur'l\thf' 用途(描述性的数据):姓名,性别,地址,学历,密码:alex3714 name...='egon' 取值: 首先要明确,字符串整体就是一个值,只不过特殊之处在于: python中没有字符类型,字符串是由一串字符组成,想取出字符串中 的字符,也可以按照下标的方式取得

    95860

    python字符串方法详解

    基本操作  len()、max()、min(),获取数据的长度、序列中元素最大、最小值,sum()获取列表或元组中元素之和 tip:min max返回的是值不是位置索引(区别于R)字节数据返回ASCII...;eg:first,*s,last = [1,2,3,4,5]去掉最大值和最小值  字符串  字符串或串(String)是由数字、字母、下划线组成的一串字符,是编程语言中表示文本的数据类型,是不可变的数据类型...编码字符  函数及使用描述chr(u)x为Unicode编码,返回其对应字符ord(x)x为字符,返回其对应的Unicode编码 从python 3.0开始,字符串存储为Unicode,即字符串中的每个字符都由代码点表示...str是出现在字符串中还是字符串的子字符串,如果找到返回索引,否则返回-1 str.rfind(beg = 0, end = len(string))与find相同,只是从字符串右边开始查找 str.index...中的元素使用s连接起来,iterable必须全部都是字符串类型,否则报错  s.splitines() 可以指定各种换行符,最常见的是\n,\r,\r\n如果指定keepends为true则保留所有的换行符

    1.2K00

    Python 基础知识

    字面常量 一个字面常量(Literal Constants)的例子是诸如 5、1.23 这样的数字,或者是如 这是一串文本 或 This is a string 这样的文本。...He said "Bond, James Bond." ''' 字符串是不可变的 这意味着一旦你创造了一串字符串,你就不能再改变它。尽管这看起来像是一件坏事,但实际上并非如此。...请注意,Python 从 0 开始计数,这意味着索引中的第一位是 0,第二位是 1,以此类推。...类似地, 你必须在使用双引号括起的字符串中对字符串内的双引号使用转义序列。同样,你必须使用转义序列 \\ 来指定反斜杠本身。 如果你想指定一串双行字符串该怎么办?...原始字符串 如果你需要指定一些未经过特殊处理的字符串,比如转义序列,那么你需要在字符串前增加 r 或 R 来指定一个 原始(Raw) 字符串。

    81131

    Python数据类型总结

    ) h[0]='J'#修改列表中的某一个值 print(id(h)) #4498034504 #4498034504 Ø 证明字典是可变类型: h={'x':1,'y':2} print(id(h))...: x=float(1.22) print(type(x)) 1.4.2字符串str 作用:名字,性别,国籍,地址等描述信息 定义:在单引号、双引号、三引号内,由一串字符组成 x=str('jiang'...('*'))取*号中间的部分 print(name.lstrip('*'))取*号左边的部分 print(name.rstrip('*'))取*号右边的部分   name='egon' print(name.lower..."数字"的方法 age=input('>>: ') print(age.isdigit()) 求字符串的长度: j='asd' print(len(j)) 成员运算in和not in :判断一个子字符换是否存在于一个大字符串中...: 按存储空间的占用从低到高 数字 字符串 集合:无序,即无序存索引相关信息 元组:有序,需要存索引相关信息,不可变 列表:有序,需要存索引相关信息,可变,需要处理数据的增删改 字典:无序,需要存key

    47220

    python字符串常用方法及汇总

    字符串常用方法 字符串基本特点 引号创建字符串 空字符串和 len()函数 转义字符 字符串拼接 字符串复制 不换行打印 从控制台读取字符串 str()实现数字转型字符串 使用[]提取字符 replace...去除首尾信息 大小写转换 格式排版 其他方法 字符串的格式化 format()基本用法 填充与对齐 数字格式化 其他格式,供大家参考: 可变字符串 Python的字符串内建函数 字符串基本特点 很多人初学编程时...我们 在面向对象章节中详细讲解这部分内容。 使用[]提取字符 字符串的本质就是字符序列,我们可以通过在字符串后面添加[],在[]里面指定偏移量, 可以提取该位置的单个字符。...字符串驻留:仅保存一份相同且不可变字符串的方法,不同的值被存放在字符串驻留池中。...{:<10d} 13 左对齐 (宽度为 10) 13 {:^10d} 13 中间对齐 (宽度为 10) 可变字符串 在 Python 中,字符串属于不可变对象,不支持原地修改,如果需要修改其中的值,

    77120

    Python(一)

    数字 数字主要分为两种类型 —— 整数(Integers)与浮点数(Floats)。 需要注意的是: Python 中没有单独的 long 类型,int 类型可以指任何大小的整数。...: from math import * print(ceil(4.1)) # 5 print(floor(4.9)) # 5 字符串 一串字符串(String)是字符(Characters)的序列...字符串是不可变的 这意味着一旦你创造了一串字符串,你就不能再改变它。 格式化方法 有时候我们会想要从其他信息中构建字符串。我们会使用 format() 函数。...在一个字符串中,一个放置在末尾的反斜杠表示字符串将在下一行继续,但不会添加新的一行。...原始字符串 为了简化,Python 还允许用 r’’ 或 R’’ 表示 ‘’ 内部的字符串默认不转义: print('\\\t\\') # \ \ print(r'\\\t\\') # \

    78720

    超详解——Python 序列详解——基础篇

    在Python中,最常用的序列类型包括: 字符串(String):由字符组成的序列,用于表示文本。 列表(List):由任意类型的对象组成的可变序列。...元组(Tuple):由任意类型的对象组成的不可变序列。 每个序列中的元素都有一个唯一的索引,可以通过索引访问特定的元素。序列的索引从0开始,正向索引从左到右依次增加,反向索引从右到左依次减少。...(整个字符串) 在上述示例中,s[:5] 提取从起始位置到索引4的字符,s[7:] 提取从索引7到末尾的字符。 切片对象 切片对象是通过 slice() 函数创建的,用于表示切片操作。...这些函数包括: len():返回序列的长度。 max():返回序列中的最大值。 min():返回序列中的最小值。 sum():返回序列中所有元素的和(适用于数字序列)。...len() 函数分别返回字符串、列表和元组的长度。

    1.1K10

    Lua 基础

    使用 # 来计算字符串的长度 在对一个数字字符串上进行算术操作时,Lua 会尝试将这个数字字符串转成一个数字 function 由 C 或 Lua 编写的函数 userdata 表示任意存储在变量中的...多返回值 Lua函数中,在return后列出要返回的值的列表即可返回多值。 可变参数 Lua 函数可以接受可变数目的参数,和 C 语言类似,在函数参数列表中使用三点 ... 表示函数有可变的参数。...('#', …) 返回可变参数的长度function average(...)...连接两个字符串 一元运算符,返回字符串或表的长度。...Lua 字符串 Lua 语言中字符串可以使用以下三种方式来表示: 单引号间的一串字符。 双引号间的一串字符。 [和]间的一串字符。

    2.2K00

    Java基础专题(三):字符串

    子串 String类的substring方法可以从一个较大的字符串提取出一个子串。...这里要复制位置为0,1和2(从0到2,包括0和2)的字符。在substring中从0开始计数,直到3为止,但不包括3。 substring有一个优点:容易计算字串的长度。...size = String.join(" / ", "S", "M", "L", "XL"); //size = "S / M / L / XL" 不可变字符串 由于不能修改Java字符串中的字符,...所以在Java文档中将String类对象称为不可变字符串,如同数字3永远是数字3一样,字符串“Hello”永远包含字符 H,e,l,l 和 o 的代码单元序列,而不能修改戏中的任何一个字符。...Java的设计者认为共享所带来的高效率远远胜于提取,拼接字符串所带来的低效率,因为我们很少需要修改字符串,更多的,我们是对字符串进行比较。

    61740

    Python 基础(字符串)

    Python中三引号可以将复杂的字符串进行赋值。Python三引号允许一个字符串跨多行,字符串中可以包含换行符、制表符以及其他特殊字符。 python字符串是不可变数据类型,有序数据类型。...字符串的切片,就是从原字符串中提取一部分出来,可以是连续的,也可以是离散的。 那么字符串依靠的是什么来取得呢?那就是索引。 元素1 元素2 元素3 ......三个检索的方法 检索方法即通过一定的函数,寻找一串字符串内所包含某个字符或字符串的计数、位置等。...False isdigit() 如果字符串只包含数字则返回 True 否则返回 False.. islower() 如果字符串中包含至少一个区分大小写的字符,并且所有这些(区分大小写的)字符都是小写,...则返回 True,否则返回 False isnumeric() 如果字符串中只包含数字字符,则返回 True,否则返回 False isspace() 如果字符串中只包含空白,则返回 True,否则返回

    71530

    python初学者笔记—入门基础知识

    可以通过id()、type()、print()三个函数查看 二、标识符命名规则: 1、标识符由字母、数字、下划线、中文 2、开头的字符不能使数字 >>> 1abc=100 File "...五、数据类型 基础数据类型:数值型(整形 浮点数 布尔值 复数) 字符串 综合数据类型:列表 元组 字典 集合 数值型 整形 int(下标、元素的提取) a=100 b=200 c=-5 d=26...ValueError: invalid literal for int() with base 10: 'abc' float('3.14') float(3) str(123) str(3.14) # 需要数字具有字符串的特性时...,age,weight)) # 1、输入一串字符,并返回它的长度。...('%s的职业是%s,目前%s岁,在%s工作每个月能拿%s'%(info[2][0],info[2][2],info[2][1],info[2][4],info[2][3])) # 将列表中的数字都做平方处理

    97231

    Python3学习笔记 | 四、Python的类型与运算-字符串(上)

    在Python里字符串被划分为不可变序列这一类别,这意味着这些字符串所包含的字符存在从左至右的位置顺序,并且他们不可以在远处修改。...:”Line1\tadded tab\nLine2” • Raw字符串:r”C:\My\new\Directory\file.exe” • Python 3.x中的Byte字符串:b’Te\x01xt’...三、字符串操作 1、len() 在Python里有很多函数,可以对字符串进行操作:len()是看字符串长度的。...D o r a E m o n 这个意思是,我们从a字符串(序列)里按顺序提取字符,进行操作。关于循环,后面在函数章节讲解。...提取单个字母时,需使用字母前的数字。比如:h,就是1或者-13,提取范围时是开始字母的前面的数字到最后字母的后面数字。

    1K20

    深入理解 RPC 消息协议设计

    本节主要涉及的知识点和它们之见的关系如下图: ? 对于一串消息流,我们必须能确定消息边界,提取出单条消息的字节流片段,然后对这个片段按照一定的规则进行反序列化来生成相应的消息对象。...对于接收端来说它看到的只是一串串的字节数组,如果没有明确的消息边界规则,接收端是无从知道这一串字节数组究竟是包含多条消息还是只是某条消息的一部分。 比较常用的两种分割方式是特殊分割符法和长度前缀法。...消息发送端在每条消息的末尾追加一个特殊的分割符,并且保证消息中间的数据不能包含特殊分割符。比如最为常见的分割符是\r\n。...比如 HTTP 的消息头采用的是纯文本外加\r\n 分割符,而消息体则是通过消息头中的 Content-Type 的值来决定长度。...下一节我们将讲一个具体的实例,拿市场上应用最广的开源存储中间件 Redis 的消息协议为例进行详细分析。

    1.1K30

    初识C语言(上):基本了解C语言的基础知识,对C语言有一个大概的认识。

    //float //单精度浮点数 //double //双精度浮点数 4、变量、常量 生活中的有些值是不变的(比如:圆周率,性别,血型等等) 有些值是可变的(比如:年龄,体重,...不变的值,C语言中用常量的概念来表示,变得值C语言中用变量来表示。 变量的命名 只能由字母(包括大写和小写)、数字和下划线( _ )组成。 不能以数字开头。 长度不能超过63个字符。...(Double Quote)引起来的一串字符称为字符串字面值(String Literal),或者简称字符串。...注:字符串的结束标志是一个 \0 的转义字符。在计算字符串长度的时候 \0 是结束标志,不算作字符串 转义字符 转义字符 释义 \?...如: \130 X \xdd dd表示2个十六进制数字。如: \x30 0 \" 用于表示一个字符串内部的双引号 重点说一下\ddd与\xdd \ddd 为什么打印出来的结果是X呢?

    68910

    Python 再牛,在字符串排序上还是被 Julia 和 R 碾压

    Julia、R、Python 当单个字符串的数量接近数字字符串时,Julia 是最快的,用了 Numpy 排序的 Python 第二,R 最慢。...我的理解是: 1. 数据以特定大小的页面加载到内存中(在大多数64位机器上,大小至少为4kb)。 2. 当字节加载时,可以从同一页面内的任何位置加载,但跨页边界加载可能会导致程序崩溃。 3....MSD 和 LSD 算法的实现 我已经实现了 MSD 和 LSD 变量。 根据我的研究,通常情况是 MSD 算法对于可变长度字符串支持更好,并且 LSD 算法对固定长度算法最有效。...有些人甚至声称 LSD 不适用于可变长度字符串向量。 我认为这不正确,因为你可以用0表示一个空字节(即使技术上是 null)。...从我的基准测试来看,即使对于可变长度字符串,我的 MSD 实现也不像 LSD 算法那样高效,这就有点奇怪了。 因为我的大多数研究都认为 MSD 比 LSD 更具性能。

    1.2K30

    Perl语言入门系列之一

    字符串可以是各种字符的任意组合,最短的字符串不包含任何字符也即空字符串,字符串的长度没有限制(当然不能超过计算机内存)。...①单引号内的字符串直接量 单引号内的字符串直接量指的是'…'内的一串字符,除单引号本身和反斜线外,单引号内的所有字符都代表他们本身,要表示单引号或者反斜线,在需要在前面再加反斜线来转义,如下所示: 'fred...②双引号内的字符串直接量 双引号内的字符串直接量指的是"…"内的一串字符,与单引号相比,双引号内更广泛的使用转义符号\,这和shell变量是类似的,如下所示: "fred" "hello\nworld"...第1个元素之后的2个元素,@array变成("pebble","barney", "betty"),@removed变成("dino","fred") 指定第四个参数后会将提取的元素替换为给出的列表,替换的列表长度和拿走的列表长度不一定相同...从数组array中拿出元素并赋值给removed,这时候原数组少了元素,而数组removed结果为提取的元素而不是array的处理结果,splice相当于同时对两个数组进行操作,这与其他编程语言的逻辑是有很大差别的

    1.6K30
    领券