精华内容
下载资源
问答
  • 字符串提取数字

    2017-07-06 10:52:17
    js实现在字符串提取数字 function getNum(text){ var value = text.replace(/[^0-9]/ig,""); alert(value); }

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml">
    <head>
    <meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
    <title>js实现在字符串中提取数字</title>
    <script language="javascript" type="text/javascript">
    function getNum(text){
    var value = text.replace(/[^0-9]/ig,"");
    alert(value);
    }
    </script>
    </head>


    <body>
    <input type="text" id="btn_getNum"/>
    <input type="button" value="得到数字" οnclick="getNum(btn_getNum.value);"/>
    </body>
    </html>

    展开全文
  • 学习Excel技术,关注微信公众号:excelperfect上篇文章讲解了提取位于字符串开头的数字的公式技术,本文研究从字符串开头提取数字的技术:1. 这些数字是连续的2. 这些连续的数字位于字符串的末尾3. 想要的结果是将...

    学习Excel技术,关注微信公众号:

    excelperfect

    上篇文章讲解了提取位于字符串开头的数字的公式技术,本文研究从字符串开头提取数字的技术:

    1. 这些数字是连续的

    2. 这些连续的数字位于字符串的末尾

    3. 想要的结果是将这些连续的数字返回到单个单元格

    与上篇文章一样,对于下面研究的每种解决方案,我们需要在两种不同的情况下测试其健全性:

    1. 字符串中除末尾外其他地方没有数字的情况,例如ABC456

    2. 字符串中除末尾外其他地方也有数字,要么在开头,要么在中间,例如123ABC456ABC123DEF456

    MIN与FIND

    公式1

    =0+MID(A1,MIN(FIND({0,1,2,3,4,5,6,7,8,9},A1& 1/17)),LEN(A1))

    如果单元格A1中的内容为“ABC456”,那么上述公式1返回“456”。其解析过程如下:

    =0+MID(“ABC456”,MIN(FIND({0,1,2,3,4,5,6,7,8,9},“ABC456” & 1/17)),LEN(“ABC456”))

    A1后面添加1/17与在其后面添加字符串“0123456789”效果相同,详见《Excel公式技巧08. 17分之一和其他全数字(pandigitals)》。主要是必须将A1与包含09的所有数字的字符串连接起来,以防止MIN函数返回错误。因为如果A1不包含0-9的所有数字,那么FIND函数的返回值至少有一个是错误值,由于MIN函数不会忽略错误值,会导致整个公式的结果也是一个错误值。通过首先在A1中的字符串末尾添加一个适当的值(例如1/173^45,“0123456789”),可以保证该字符串将包含至少一个0-9中的每个数字(因此FIND函数的所有10个返回值都是非错误值),同时通过将字符串放在A1的末尾确保我们不会影响MIN函数所需的输出。

    这样,现在上述公式转换为:

    =0+MID("ABC456",MIN(FIND({0,1,2,3,4,5,6,7,8,9},"ABC456"&0.0588235294117647)),LEN("ABC456"))

    可能你还不知道,在某些公式结构中,MIN函数具有强制返回数组的能力,且无需按Ctrl+Shift+Enter组合键。本例就属于这种情况,因此FIND函数将对传递给它的所有10个值进行操作,而不仅仅是对第一个值进行操作。因此,上述公式转换为:

    =0+MID("ABC456",MIN({7,19,13,14,4,5,6,21,11,17}),LEN("ABC456"))

    MIN函数返回字符串中数字开始的位置4,因此,上述公式转换为:

    =0+MID("ABC456",4,LEN("ABC456"))

    注意,MID函数(以及RIGHT函数和LEFT函数)具有一些有用的特性,当传递的参数num_chars的值大于要提取的实际字符串的长度时不会出错。也就是说,如果该参数的值将导致全部或部分返回值超出字符串末尾的情况时,则这些函数仅返回从指定位置到字符串末尾的那些字符。这里将参数num_chars的值指定为LEN(A1),因为没有子字符串的长度会大于字符串自身的情况。这样,上述公式转换为:

    =0+MID("ABC456",4,6)

    得到结果:

    456

    下面我们看看如果单元格A1中的字符串包含其它数字例如123ABC456,公式1是否有效。此时公式1转换为:

    =0+MID(“123ABC456“,MIN(FIND({0,1,2,3,4,5,6,7,8,9},"123ABC4560.0588235294117647")),LEN(A1))

    转换为:

    =0+MID(“123ABC456“,MIN({10,1,2,3,7,8,9,24,14,20}),LEN(A1))

    转换为:

    =0+MID(“123ABC456“,1,LEN(“123ABC456“))

    转换为:

    =0+MID(“123ABC456“,1,9)

    由于字符串中有其它数字的影响,导致找到的传递到MID函数的起始位置变化,因此结果为:

    #VALUE!

    LOOKUP与RIGHT

    公式2

    =-LOOKUP(0,-RIGHT(A1,ROW(INDIRECT("1:"& LEN(A1)))))

    这个公式与上一篇文章《Excel公式技巧10:从字符串中提取数字——数字位于字符串开头》中的公式1相似,只是使用RIGHT函数代替了LEFT函数。

    当然,如果单元格A1中的字符串与“JAN18”、“123E4”类似,则不会返回正确的结果,详细原因参见上篇文章。

    RIGHT、MATCH与ISNUMBER

    公式3

    =0+RIGHT(A1,MATCH(FALSE,ISNUMBER(0+MID(A1,1+LEN(A1)-ROW(INDIRECT("1:"& LEN(A1))),1)),0)-1)

    这是一个数组公式。

    仍以单元格A1中的数据为“ABC456”,公式3可转换为:

    =0+RIGHT(“ABC456”,MATCH(FALSE,ISNUMBER(0+MID(“ABC456”,1+6-ROW(INDIRECT("1:"& 6)),1)),0)-1)

    转换为:

    =0+RIGHT(“ABC456”,MATCH(FALSE,ISNUMBER(0+MID(“ABC456”,1+6-{1;2;3;4;5;6},1)),0)-1)

    转换为(注意,这里是如何将得到的数组颠倒,从而使得从字符串的末尾到开头逐个获取字符成为可能):

    =0+RIGHT(“ABC456”,MATCH(FALSE,ISNUMBER(0+MID(“ABC456”,{6;5;4;3;2;1},1)),0)-1)

    转换为:

    =0+RIGHT(“ABC456”,MATCH(FALSE,ISNUMBER(0+{6;5;4;C;B;A}),0)-1)

    通过适当的数学运算(将数组与0相加),强制数字字符转换成数字:

    =0+RIGHT("ABC456",MATCH(FALSE,ISNUMBER({6;5;4;#VALUE!;#VALUE!;#VALUE!}),0)-1)

    ISNUMBER函数忽略传递给其参数中的错误值:

    =0+RIGHT("ABC456",MATCH(FALSE,{TRUE;TRUE;TRUE;FALSE;FALSE;FALSE},0)-1)

    转换为:

    =0+RIGHT("ABC456",4-1)

    其中的4表示在字符串“”中第一个非数字字符自右向左出现的位置,减1表示数字字符出现的位置:

    =0+RIGHT("ABC456",3)

    结果为:

    456

    下面,我们来看看字符串中除末尾以外的数字会不会影响最终的结果。例如如果单元格A1中的数据是“123ABC456”,那么公式3可以转换为:

    =0+RIGHT(“123ABC456”,MATCH(FALSE,ISNUMBER(0+MID(“123ABC456”,1+LEN(“123ABC456”)-ROW(INDIRECT("1:"& LEN(“123ABC456”))),1)),0)-1)

    转换为:

    =0+RIGHT(“123ABC456”,MATCH(FALSE,ISNUMBER(0+{“6”;”5”;”4”;”C”;”B”;”A”;”3”;”2”;”1”}),0)-1)

    转换为:

    =0+RIGHT(“123ABC456”,MATCH(FALSE,ISNUMBER(6;5;4;#VALUE!; #VALUE!; #VALUE!;3;2;1}),0)-1)

    转换为:

    =0+RIGHT(“123ABC456”,MATCH(FALSE,{TRUE;TRUE;TRUE;FALSE;FALSE;FALSE;TRUE;TRUE;TRUE},0)-1)

    转换为:

    =0+RIGHT("ABC456",4-1)

    其中的4表示在字符串“”中第一个非数字字符自右向左出现的位置,减1表示数字字符出现的位置:

    =0+RIGHT("ABC456",3)

    结果为:

    456

    可以看到,由于是从右向左取数,因此在字符串的其它位置存在数字并不会影响结果。

    RIGHT、MATCH与ISERR

    公式4

    =0+RIGHT(A1,MATCH(1,0+ISERR(0+MID(A1,1+LEN(A1)-ROW(INDIRECT("1:"& LEN(A1))),1)),0)-1)

    这是一个数组公式。

    以单元格A1中的数据为“123ABC456”,公式4可转换为:

    =0+RIGHT("123ABC456",MATCH(1,0+ISERR(0+{"6";"5";"4";"C";"B";"A";"3";"2";"1"}),0)-1)

    转换为:

    =0+RIGHT("123ABC456",MATCH(1,0+{FALSE;FALSE;FALSE;TRUE;TRUE;TRUE;FALSE;FALSE;FALSE},0)-1)

    转换为:

    =0+RIGHT("123ABC456",MATCH(1,{0;0;0;1;1;1;0;0;0},0)-1)

    转换为:

    =0+RIGHT("123ABC456",4-1)

    转换为:

    =0+RIGHT("123ABC456",3)

    结果为:

    456

    与公式3一样,字符串中除末尾有数字外其它部位存在数字时不影响结果。

    注:本技巧整理自excelxor.com,有兴趣的朋友可以研阅原文,特别是原文后面的评论。

    db3646bbdd7dfce8fd0dae5913782f36.png

    展开全文
  • //根据时间字符串提取数字(例:“19:30:00”) hour_minute_t num(char *p) { hour_minute_t time; int num = 0; char q[20] = {0}; int i; int j = 0; for(i = 0; p[i] != '\0'; i++) { if(p[...

    //根据时间字符串提取数字(例:“19:30:00”)
    hour_minute_t num(char *p)
    {
        hour_minute_t time;
        int  num = 0;
        char q[20] = {0};
        int i;
        int j = 0;
        for(i = 0; p[i] != '\0'; i++)
        {
            if(p[i]>='0' && p[i] <= '9')
            {
                printf("-----------\n");
                q[j++] = p[i];

            }    
        }
        printf("-----------\n");
        num = atoi(q);
        time.hour = num/10000;
        time.minute = num/100%100;
        printf("hour : %d\n",time.hour);
        printf("minute : %d\n",time.minute);
        return time;
    }

    展开全文
  • 正则表达式是一个特殊的字符序列,...利用正则表达式从字符串提取数字主要用到下面几个函数:(1)compile 函数根据一个模式字符串和可选的标志参数生成一个正则表达式对象。该对象拥有一系列方法用于正则表达式匹配...

    正则表达式是一个特殊的字符序列,它能帮助你方便的检查一个字符串是否与某种模式匹配。

    Python 自1.5版本起增加了re 模块,它提供 Perl 风格的正则表达式模式。

    re 模块使 Python 语言拥有全部的正则表达式功能。利用正则表达式从字符串提取数字主要用到下面几个函数:

    (1)compile 函数根据一个模式字符串和可选的标志参数生成一个正则表达式对象。该对象拥有一系列方法用于正则表达式匹配和替换。

    语法格式为:

    re.compile(pattern[, flags])

    参数:

    • pattern : 一个字符串形式的正则表达式
    • flags 可选,表示匹配模式,比如忽略大小写,多行模式等,具体参数为:
    • re.I 忽略大小写
      • re.L 表示特殊字符集 \w, \W, \b, \B, \s, \S 依赖于当前环境
      • re.M 多行模式
      • re.S 即为' . '并且包括换行符在内的任意字符(' . '不包括换行符)
      • re.U 表示特殊字符集 \w, \W, \b, \B, \d, \D, \s, \S 依赖于 Unicode 字符属性数据库
      • re.X 为了增加可读性,忽略空格和' # '后面的注释

    (2)re.match 尝试从字符串的起始位置匹配一个模式,如果不是起始位置匹配成功的话,match()就返回none。

    函数语法

    re.match(pattern, string, flags=0)

    (3)re.search 扫描整个字符串并返回第一个成功的匹配。

    函数语法:

    re.search(pattern, string, flags=0)
    注:

    re.match只匹配字符串的开始,如果字符串开始不符合正则表达式,则匹配失败,函数返回None;而re.search匹配整个字符串,直到找到一个匹配。

    (4)findall

    在字符串中找到正则表达式所匹配的所有子串,并返回一个列表,如果没有找到匹配的,则返回空列表。

    注意: match 和 search 是匹配一次 findall 匹配所有。

    语法格式为:

    findall(string[, pos[, endpos]])

    参数:

    • string 待匹配的字符串。
    • pos 可选参数,指定字符串的起始位置,默认为 0。
    • endpos 可选参数,指定字符串的结束位置,默认为字符串的长度。

    下面是实现的具体方法:

    def findnum(string):
        comp=re.compile(-?[1-9]\d*)
        list_str=comp.findall(string)
        list_num=[]
        for item in list_str:
            item=int(item)
            list_num.append(item)
        return list_num

    re.compile()的一些匹配参数:

    [1-9]\d*      正整数
    -[1-9]\d*   负整数
    -?[1-9]\d* 整数
    [1-9]\d*|0  非负整数
    -[1-9]\d*|0   非正整数
    [1-9]\d*\.\d*|0\.\d*[1-9]\d*$   正浮点数
    -([1-9]\d*\.\d*|0\.\d*[1-9]\d*)$  负浮点数
    -?([1-9]\d*\.\d*|0\.\d*[1-9]\d*|0?\.0+|0)$  浮点数


    展开全文
  • -- ======================================== -- Author:<Oliver QIN> -- Date :<...字符串提取数字/汉字/英文字母> -- ======================================== --提取数字 ...
  • 因工作原因,很久没有学习python知识了,感觉都快忘记了,前天看到一个练习题,如何将字符串中的数字提取出来,然后求和呢?下面我来解释一下如何通过python代码来实现。题目:字符串43...3y2.f67se2.666. 将其中的...
  • java字符串提取数字

    千次阅读 2018-09-14 17:08:52
    * 提取字符串中的数字 * @param strInput * @return */ public static String getNum(String strInput) { //匹配指定范围内的数字 String regEx = "[^0-9]"; //Pattern是一个正则表达式经...
  • 字符串提取数字

    2019-10-01 03:51:22
    代码如下 1 import re 2 # 找到226个,抽取数字 3 total = '找到 22 6 个 ' ...在'找到 22 6 个 '这个字符串中找到非数字的字符(正则表达式中'\D'表示非数字),并用""替换,然后返回的就是只剩下数字的字...
  • Oracle字符串提取数字

    2020-03-18 15:05:03
    场景:用户需要从memo字段中获取,实时扣款:后的扣款...2.截取实时扣款以及后面一小 case when instr(memo,‘实时扣款’)>0 then substr(memo,instr(memo,‘实时扣款’),15) when instr(memo,‘划扣’)>0 t...
  • JS字符串提取数字

    2020-06-03 11:14:49
    JS部分代码 var key = "zifuchuan111" var shuzi = key.replace(/[^0-9]/ig,""); console.log("shuzi:",shuzi); //打印显示的是111
  • +------+--------+ | id | str | +------+--------+ | 1 | abc123 | | 2 | 123abc | | 3 | 1abc23 | | 4 | abc | | 5 | 123 | +------+--------+ 5 rows in set (0.00 sec) 需要提取字符数字里面的数字 二....
  • shell 字符串提取数字

    2018-09-17 21:38:00
    echo "2014年7月21日" | tr -cd "[0-9]" 这样就可以提取出2014721 转载于:https://www.cnblogs.com/sea-stream/p/9665087.html
  • 第一种方法数据库自有的函数如图,这种可行,但是只存在,数字在前面时。这里我们只能通过自定义函数解决。 如果遇到数字在中间或者后面取不到值,如图所示: 最友好的解决方式: 首先执行一个自定义函数,...
  • z]%',@S)>0 BEGIN set @s=stuff(@s,patindex('%[^a-z]%',@s),1,'') END RETURN @S END GO --测试 select dbo.F_Get_STR('测试ABC123ABC') GO /* 功能:获取字符串中的数字 */ create function dbo.F_Get_Number (@S ...
  • C# 字符串提取数字

    2017-04-05 09:55:00
    转自:... 一、使用正则表达式 1 string str = "sztq数字提取123sztq数字提取"; 2 string result = System.Text.RegularExpressions.Regex.Replace(str, @"[^0-9]+", ""); 3 Consol...
  • java-字符串提取数字

    2020-01-09 16:33:03
    方法1 public static void main(String[] args) { String str1 = "HDCBjvjk4566HV1111FJKDjvck锯齿块从就是杜康145632.+=%hcjkd"; StringBuffer str2 = new StringBuffer(); Boolean bool = false;...
  • c++ 字符串提取数字字母

    千次阅读 2019-08-08 19:19:11
    使用std::regex库 #include <regex> #include <string> #include <iostream> using namespace std; int main() ... std::string s("sdfedDFV[]#@s1234");... std::regex e("([a-z0-9A-Z...

空空如也

空空如也

1 2 3 4 5 ... 20
收藏数 3,001
精华内容 1,200
关键字:

字符串提取数字