首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

从邮件地址中提取姓名,我的超级公式,有这么复杂么?

标签:Excel公式练习 这是一个有趣的题目,假设电子邮件地址的格式如下: 名字任何非字母.字符姓氏@email.com 说明: 1.假设姓名中只有英文字母。...2.电子邮件地址只包含名字_分隔符_姓氏,没有中间或其他前缀或后缀等。 3.电子邮件地址在单元格A1中。...5.在单元格C1D1中,是需要提取的名字姓氏。 示例数据如下图1所示。 图1 注:示例数据来源于chandoo.org。...看到这个示例后,我的第一反应就是利用ASCII字符代码,因为小写字母的字符代码在97122之间,因此,我可以获取“@”前的字符,看其是否在97122之间,从而提取出相应的字符串。...利用提取出的名字,去掉前面的名字部分,然后按相同的思路,提取姓氏

1.9K30

C++实现字符串分割函数split()「建议收藏」

需求:对一个字符串进行分割,然后将分割后的数据存起来,想用的时候像数组那样拿就行了。所以在完成分割后,需要使用vector将相应的数据保存起来。...行为先前存储的指针作为str传递的行为相同。...(3)大多数其他strtok不同,每个后续标记中的定界符可以不同,甚至可以取决于先前标记的内容。 (4)其中delim可以包含多个分隔符,strtok函数会将str内容按分隔符分割。...str为要分解的字符串,delim为分隔符字符串。char **saveptr参数是一个指向char *的指针变量,用来在strtok_r内部保存切分时的上下文,以应对连续调用分解相同源字符串。...strtok_r实际上就是将strtok内部隐式保存的this指针,以参数的形式函数外部进行交互。由调用者进行传递、保存甚至是修改。

1.7K10

C语言字符串相关函数使用示例 strtok_r strstr strtok atoi

函数介绍示例 strtok_r 首先需要将字符串切分为指令参数形式,需要用到strtok_r函数。...__last); 参数:原始字符串,分隔符,切分后剩余的字符串 返回值:切分出的字符串,若没有符合的字符串,则返回一个空指针 注意:该函数是一种破坏性操作,分割处理后原字符串 str 会被改变,变成了切分出的字符串...我们将上面问题中的str作为原始字符串传入,分隔符选用逗号,切分后的保存在上面定义的paras变量中,返回值保存在上面定义的cmd变量中: char *cmd;//表示命令 char *paras;//...r\n", paras);//获取后续字符串 查看测试结果: cmd:led paras:100,0,80,15 可以看到成功切分出了我们需要的命令参数两种字符串。...printf("\r\ntest [strtok_r] --------------------->\r\n"); cmd = strtok_r(str, ",", ¶s); printf

1.4K41

SQL函数 $TRANSLATE

它将字符串中的每个字符标识符参数中的每个字符进行比较。如果 $TRANSLATE 找到匹配项,它会记下该字符的位置。...REPLACE 可以另一个子字符串替换一个或多个字符的单个指定子字符串,或删除指定子字符串的多个实例。 $TRANSLATE 可以相应的指定替换字符替换多个指定字符。...请注意,标识符将撇号加倍以将其转义为文字字符,而不是字符串分隔符:SELECT TOP 20 Name,$TRANSLATE(Name,', .''-') AS AlphaName FROM Sample.PersonWHERE...Name %STARTSWITH 'O'在以下示例中,三参数 $TRANSLATE 通过将逗号空格替换为插入符号 (^) 字符来修改名称值,返回以三部分分隔的名称(姓氏名字中间首字母)。...Name %STARTSWITH 'O'在以下示例中,三参数 $TRANSLATE 通过将逗号空格替换为脱字符 (^) 字符(在标识符关联符中指定)删除句点、撇号连字符(在标识符中指定,从关联人

94930

因为一个函数strtok踩坑,我被老工程师无情嘲笑了(一)

ID:技术让梦想更伟大 作者:李肖遥 在用C/C++实现字符串切割中,strtok函数经常用到,其主要作用是按照给定的字符集分隔字符串,并返回各子字符串。...strtok_r实际上就是将strtok内部隐式保存的this指针,以参数的形式函数外部进行交互。由调用者进行传递、保存甚至是修改。...的代码比调用strtok的代码多了两个指针,outer_ptrinner_ptr。...strtok_r将原内部指针显示化,提供了saveptr这个参数。增加了函数的灵活性安全性。...分隔符字符由delim指向的以空字符结尾的字节字符串标识。 该函数被设计为被称为倍数时间以从相同的字符串获得连续的令牌。 这里大家可以参考,我在这里不多讲了。

7.4K31

hanlp自然语言处理包的人名识别代码解析

,各命名实体识别准确率 nr 33% ns 83% nt 43% 姓氏过滤后,各命名实体识别准确率 nr 36% ns 83% nt 81% 这里没有开层叠隐马预测机构地名,nt上升原因估计是由于很多不是人名的词语没被标为人名...,那么nt的模式匹配规则匹配不上了,所以机构准确率上来了。...但是到了实体识别则不一定,拿人名来说,除了姓氏以外,名字词语部分可以填充的词语是任意的,也就是说任何词语都有可能出现在中间位置,此时发射矩阵中的某些词实际上就没有太大意义了,因为它可能等可能的由BIEO...因此,我们通过引入角色标记,实际上这就引入了先验知识,比如某些字只能由姓氏标记产生,某些字一般情况都充当名字首字,某些字一般情况都充当名字末字,通过给这些不同情况下的字集按照其出现的位置的分布其语法意义做角色定义...下边介绍一下HanLP人名识别的主要流程 1.使用使用匹配法求出各种分词路径变量wordNetAll存储 2.viterbi方法找到一条最优的分词路径,这里主要使用用户自定义词典以及核心词典,序列变量

88230

Python学习手册--第五部分(函数)

名字中间时,程序正常运行。...然而并不是所有人都是有中间的,但如果你只传入姓氏名字的话,显然程序会报错,那该怎么办呢?...由于人都有名姓,因此在函数定义中首先列出了这两个形参。中间是可选的,因此在函数定义中最后列出该形参,并将其默认值设置为空字符串。 在函数体中,我们检查是否提供了中间。...如果提供了中间,就将名、中间姓合并为姓名,然后将其修改为首字母大写格式,并返回到函数调用行。在函数调用行,将返回的值存储在变量name 中;然后将这个变量的值打印出来。...import sum numbers = (1, 2, 3, 4, 5, 6, 7, 8, 9) sum = sum(numbers) print(sum) 在sum后面还可以跟上任意数量的函数名,中间逗号分隔

67820

jq tmpl输出编码html,jQuery tmpl 讲解「建议收藏」

jQuery的一个类库 (2)一个轻量级的前端模板引擎(vue.js也是一种前端模板引擎) (3)可以在模板中实现逻辑运算 2、jQuery-tmpl的语法 (1)占位:${变量}或{ {= 变量}} 注:=变量之间一定要有空格...例如: {type} 中文姓名: 1.乘客姓名必须所持证件一致。 2.名字中含生僻字可直接输入拼音代替。例:“王鬳”可输入为“王 yan”或者“王-yan”。...英文姓名: 1.必须用英文字母填写,并确保所持证件一致。...如乘客姓名为 Green(姓)/Jim() Stephanie(中间),则在“姓(拼音或英文)”栏中输入 Green;在“(拼音或英文)”栏中输入 JimStephanie(注:中间需空一格紧随之后...3.英文名字的长度不可超过 26 个字符,如名字过长请使用缩写,乘客的姓氏不能缩写,可以缩写。姓氏中如包括空格请在输入时删掉空格。 4.英文姓名不可少于 2 个英文单词。

1.5K20

单列文本拆分为多列,Python可以自动化

标签:PythonExcel,pandas 在Excel中,我们经常会遇到要将文本拆分。Excel中的文本拆分为列,可以使用公式、“分列”功能或Power Query来实现。...示例文件包含两列,一个人的姓名出生日期。 图2 我们的任务如下: 1.把名字姓氏分开 2.将出生日期拆分为年、月日 让我们将数据加载到Python中。...看一个例子: 图6 上面的示例使用逗号作为分隔符,将字符串拆分为两个单词。从技术上讲,我们可以使用字符作为分隔符。注意:返回结果是两个单词(字符串)的列表。 那么,如何将其应用于数据框架列?...让我们在“姓名”列中尝试一下,以获得名字姓氏。 图7 拆分是成功的,但是当我们检查数据类型时,它似乎是一个pandas系列,每行是包含两个单词的列表。...现在,我们可以轻松地将文本拆分为不同的列: df['名字'] = df['姓名'].str.split(',',expand=True)[1] df['姓氏'] = df['姓名'].str.split

6.9K10

第一胎都还没有,我就用Python早早的帮第三胎起好名了

而python取名字的方法挺多的,像爬虫+jieba+reaom就可以简单的构建一个取名程序,但比较麻烦,所以本文讲解其他两种方法。...(locale='zh_CN') 直接里面的name方法可以直接生成一个名字,加上for循环可以直接生成10个名字: for i in range(10): name = fk.name()...当然这不是我们想要的,直接name方法生成的姓名不分性别、姓氏的,所以要用到其它方法。 first_name_male()为男性,first_name_female()为女性。...chinesename chinesename库是专门为了生成中文名而出现的,所以功能比较完善,而用法也很简单;其中里面包含有《百家姓》姓氏504个,常用于名字的汉字2812个名字汉字中含有大量《楚辞》...girl为字符串类型。

79640

数据揭秘:中国姓氏排行榜

朋友让我这组数据随便做点啥。 这组数据如此牛逼,可以做的东西太多啦。但是,吸取了前两次文章被下架的教训,我决定做一个不那么敏感的话题。就做 “东半球第二有趣的中国姓氏排行榜”吧!...这三大姓加起来,占据中国总人口的22%(由于我们掌握的数据不是完全的随机抽样,各个姓氏的排名比例可能与其它统计结果略有不同)。...于是,我们又设计了第三个指数: 3.奔波指数 奔波指数=姓氏人均迁徙距离。迁徙距离为户籍地所在地级市现居住地所在地级市的距离。 在喜欢奔波的姓氏中,首屈一指的就是——朴,人均迁徙距离达到900km。...于是,我们设计了第四个指数: 4.装逼指数 装逼指数=名字长度在4字或以上的人口数量占该姓氏人口数量的比例。 严格来说,装逼指数最高的其实是“欧阳”“诸葛”。...但考虑到复姓少数民族姓氏的逼格并不是装出来的,我们只好排除掉这些本来就很有逼格的姓氏,只看单字大姓TOP20的装逼情况: 显然,“马”姓的装逼指数甩第二的“高”“周”一大截,这大概归功于马姓有天然的装逼优势

1.9K100

经常被人忽视的:Pandas 文本数据处理!

毋庸置疑,Pandas是使用最广泛的 Python 库之一,它提供了许多功能方法来执行有效的数据处理和数据分析。 我们平时的操作,大多围绕着数字的处理,这是因为大家习惯将表格数据数字联系起来。...df["微信"] = df["微信"].str.lower() df 我们可以通过组合姓氏名字,来创建姓名这列。...既可以在特定位置插入创建新列,也可以使用 cat 方法组合字符串(此处还可设置分隔符sep,这里并未设置)。...例如,户籍地址这列包括省份城市,我们可以通过拆分此列来提取城市的信息。...例如,我们可以“str[:5]”表达式选择前8个字符,“str[-8:]”选择后8个字符。

1.2K20

中国姓氏大数据,看看你本家的牛逼指数抱团指数

朋友让我这组数据随便做点啥。 这组数据如此牛逼,可以做的东西太多啦。但是,吸取了前两次文章被下架的教训,我决定做一个不那么敏感的话题。就做 “东半球第二有趣的中国姓氏排行榜”吧!...这三大姓加起来,占据中国总人口的22%(由于我们掌握的数据不是完全的随机抽样,各个姓氏的排名比例可能与其它统计结果略有不同)。...于是,我们又设计了第三个指数: 3、奔波指数 奔波指数=姓氏人均迁徙距离。迁徙距离为户籍地所在地级市现居住地所在地级市的距离。 在喜欢奔波的姓氏中,首屈一指的就是——朴,人均迁徙距离达到900km。...于是,我们设计了第四个指数: 4、装逼指数 装逼指数=名字长度在4字或以上的人口数量占该姓氏人口数量的比例。 严格来说,装逼指数最高的其实是“欧阳”“诸葛”。...但考虑到复姓少数民族姓氏的逼格并不是装出来的,我们只好排除掉这些本来就很有逼格的姓氏,只看单字大姓TOP20的装逼情况: 显然,“马”姓的装逼指数甩第二的“高”“周”一大截,这大概归功于马姓有天然的装逼优势

1.2K30

iOS获取通讯录联系人信息

lastName=(__bridge NSString *)(ABRecordCopyValue(people, kABPersonLastNameProperty));         //获取当前联系人中间...bridge NSString*)(ABRecordCopyValue(people, kABPersonFirstNamePhoneticProperty));         //获取当前联系人的姓氏拼音..._bridge NSString*)(ABRecordCopyValue(people, kABPersonLastNamePhoneticProperty));         //获取当前联系人的中间拼音... kABPersonManagerLabel;   // Manager 三、通讯录“写”的相关操作 看到上面读取信息的代码,你可能觉得一阵目炫,其实只是字段比较长,逻辑还是很简单的,同样,写的操作之类似...保存修改的通讯录对象     ABAddressBookSave(addBook, NULL); 四、重中之重-关于内存管理 上面的代码为了演示方便,创建的全部引用都没有释放,势必是造成内存泄露,在我们ABAddressBookCreate

1.4K40

PostgreSQL中NULL的意义

在详细介绍之前,还需要了解三值逻辑二值逻辑概念。二值是布尔值的概念,要么真,要么假。但三值逻辑可以真,也可以为假,还可以是中间值(未知)。...在下面的代码片段中,我们将 1 1 进行比较,显而易见的结果是“t”(真)。这让我们明白,当两个值匹配时,PostgreSQL 相等运算符给了我们 true。同样,相等运算符适用于文本值。...PG提供了特殊的语句函数来对NULL值进行检查测试。...下面是使用例子: 包含名字中间姓氏字段的表。每个人不一定都有名字或者中间或者姓氏。...Adams | Baker | Clark | 21 2 | Davis | | Evans | 22 3 | Ghosh | Hills | | 24 (3 rows) 我们选择有中间的学生

2.1K20
领券