linux 中强大且常用命令 find、grep

本文详细介绍了Linux下的find和grep命令的使用方法,包括find命令的多种选项和实例,如按文件名、文件类型、文件大小等查找,以及grep命令的正则表达式和常用选项,帮助用户提高在Linux环境下的文件搜索效率。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

原文链接:http://www.cnblogs.com/skynet/archive/2010/12/25/1916873.html

在linux下面工作,有些命令能够大大提高效率。本文就向大家介绍find、grep命令,他哥俩可以算是必会的linux命令,我几乎每天都要用到他们。本文结构如下:

  • find命令
    • find命令的一般形式
    • find命令的常用选项及实例
    • find与xargs
  • grep命令
    • grep命令的一般形式
    • grep正则表达式元字符集(基本集)
    • grep命令的常用选项及实例

1、find命令

find命令是一个无处不在命令,是linux中最有用的命令之一。find命令用于:在一个目录(及子目录)中搜索文件,你可以指定一些匹配条件,如按文件名、文件类型、用户甚至是时间戳查找文件。下面就通过实例来体验下find命令的强大。

1.1、find命令的一般形式

man文档中给出的find命令的一般形式为:

find [-H] [-L] [-P] [-D debugopts] [-Olevel] [path...] [expression]

其实[-H] [-L] [-P] [-D debugopts] [-Olevel]这几个选项并不常用(至少在我的日常工作中,没有用到过),上面的find命令的常用形式可以简化为:

find [path...] [expression]

  • path:find命令所查找的目录路径。例如用.来表示当前目录,用/来表示系统根目录
  • expression:expression可以分为——“-options [-print -exec -ok ...]”
  • -options,指定find命令的常用选项,下节详细介绍
  • -print,find命令将匹配的文件输出到标准输出
  • -exec,find命令对匹配的文件执行该参数所给出的shell命令。相应命令的形式为'command' {  } \;,注意{   }和\;之间的空格 
    find ./ -size 0 -exec rm {} \; 删除文件大小为零的文件 (还可以以这样做:rm -i `find ./ -size 0`  或 find ./ -size 0 | xargs rm -f &) 
    为了用ls -l命令列出所匹配到的文件,可以把ls -l命令放在find命令的-exec选项中:find . -type f -exec ls -l {  } \; 
    在/logs目录中查找更改时间在5日以前的文件并删除它们:find /logs -type f -mtime +5 -exec rm {  } \;
  • -ok,和-exec的作用相同,只不过以一种更为安全的模式来执行该参数所给出的shell命令,在执行每一个命令之前,都会给出提示,让用户来确定是否执行。 
    find . -name "*.conf"  -mtime +5 -ok rm {  } \; 在当前目录中查找所有文件名以.LOG结尾、更改时间在5日以上的文件,并删除它们,只不过在删除之前先给出提示

    也有人这样总结find命令的结构:

    find start_directory test 
         options 
         criteria_to_match 
         action_to_perform_on_results
    

    1.2、find命令的常用选项及实例

  • -name 
    按照文件名查找文件。 
    find /dir -name filename  在/dir目录及其子目录下面查找名字为filename的文件 
    find . -name "*.c" 在当前目录及其子目录(用“.”表示)中查找任何扩展名为“c”的文件
  • -perm 
    按照文件权限来查找文件。 
    find . -perm 755 –print 在当前目录下查找文件权限位为755的文件,即文件属主可以读、写、执行,其他用户可以读、执行的文件
  • -prune 
    使用这一选项可以使find命令不在当前指定的目录中查找,如果同时使用-depth选项,那么-prune将被find命令忽略。 
    find /apps -path "/apps/bin" -prune -o –print 在/apps目录下查找文件,但不希望在/apps/bin目录下查找 
    find /usr/sam -path "/usr/sam/dir1" -prune -o –print 在/usr/sam目录下查找不在dir1子目录之内的所有文件
  • -user 
    按照文件属主来查找文件。 
    find ~ -user sam –print 在$HOME目录中查找文件属主为sam的文件
  • -group 
    按照文件所属的组来查找文件。 
    find /apps -group gem –print 在/apps目录下查找属于gem用户组的文件 
  • -mtime -n +n 
    按照文件的更改时间来查找文件, - n表示文件更改时间距现在n天以内,+ n表示文件更改时间距现在n天以前。 
    find / -mtime -5 –print 在系统根目录下查找更改时间在5日以内的文件 
    find /var/adm -mtime +3 –print 在/var/adm目录下查找更改时间在3日以前的文件
  • -nogroup 
    查找无有效所属组的文件,即该文件所属的组在/etc/groups中不存在。 
    find / –nogroup -print
  • -nouser 
    查找无有效属主的文件,即该文件的属主在/etc/passwd中不存在。 
    find /home -nouser –print
  • -newer file1 ! file2 
    查找更改时间比文件file1新但比文件file2旧的文件。
  • -type 
    查找某一类型的文件,诸如: 
    b - 块设备文件。 
    d - 目录。 
    c - 字符设备文件。 
    p - 管道文件。 
    l - 符号链接文件。 
    f - 普通文件。 
    find /etc -type d –print 在/etc目录下查找所有的目录 
    find . ! -type d –print 在当前目录下查找除目录以外的所有类型的文件 
    find /etc -type l –print 在/etc目录下查找所有的符号链接文件
  • -size n:[c] 查找文件长度为n块的文件,带有c时表示文件长度以字节计。 
    find . -size +1000000c –print 在当前目录下查找文件长度大于1 M字节的文件 
    find /home/apache -size 100c –print 在/home/apache目录下查找文件长度恰好为100字节的文件 
    find . -size +10 –print 在当前目录下查找长度超过10块的文件(一块等于512字节)
  • -depth:在查找文件时,首先查找当前目录中的文件,然后再在其子目录中查找。 
    find / -name "CON.FILE" -depth –print 它将首先匹配所有的文件然后再进入子目录中查找 
  • -mount:在查找文件时不跨越文件系统mount点。  
    find . -name "*.XC" -mount –print 从当前目录开始查找位于本文件系统中文件名以XC结尾的文件(不进入其他文件系统)
  • -follow:如果find命令遇到符号链接文件,就跟踪至链接所指向的文件。

    1.3、find与xargs

    在使用find命令的-exec选项处理匹配到的文件时, find命令将所有匹配到的文件一起传递给exec执行。但有些系统对能够传递给exec的命令长度有限制,这样在find命令运行几分钟之后,就会出现溢出错误。错误信息通常是“参数列太长”或“参数列溢出”。这就是xargs命令的用处所在,特别是与find命令一起使用。

    find命令把匹配到的文件传递给xargs命令,而xargs命令每次只获取一部分文件而不是全部,不像-exec选项那样。这样它可以先处理最先获取的一部分文件,然后是下一批,并如此继续下去。

    在有些系统中,使用-exec选项会为处理每一个匹配到的文件而发起一个相应的进程,并非将匹配到的文件全部作为参数一次执行;这样在有些情况下就会出现进程过多,系统性能下降的问题,因而效率不高;

    而使用xargs命令则只有一个进程。另外,在使用xargs命令时,究竟是一次获取所有的参数,还是分批取得参数,以及每一次获取参数的数目都会根据该命令的选项及系统内核中相应的可调参数来确定。

    来看看xargs命令是如何同find命令一起使用的,并给出一些例子。

    find . -type f -print | xargs file 查找系统中的每一个普通文件,然后使用xargs命令来测试它们分别属于哪类文件

    find / -name "core" -print | xargs echo "" >/tmp/core.log 在整个系统中查找内存信息转储文件(core dump) ,然后把结果保存到/tmp/core.log 文件中:

    find . -type f -print | xargs grep "hostname" 用grep命令在所有的普通文件中搜索hostname这个词

    find ./ -mtime +3 -print|xargs rm -f –r 删除3天以前的所有东西 (find . -ctime +3 -exec rm -rf {} \;)

    find ./ -size 0 | xargs rm -f & 删除文件大小为零的文件

    find命令配合使用exec和xargs可以使用户对所匹配到的文件执行几乎所有的命令。

    2、grep命令

    grep (global search regular expression(RE) and print out the line,全面搜索正则表达式并把行打印出来)是一种强大的文本搜索工具,它能使用正则表达式搜索文本,并把匹配的行打印出来。

    2.1、grep命令的一般选项及实例

    grep [OPTIONS] PATTERN [FILE...] 
    grep [OPTIONS] [-e PATTERN | -f FILE] [FILE...]

    grep命令用于搜索由Pattern参数指定的模式,并将每个匹配的行写入标准输出中。这些模式是具有限定的正则表达式,它们使用ed或egrep命令样式。如果在File参数中指定了多个名称,grep命令将显示包含匹配行的文件的名称。对 shell 有特殊含义的字符 ($, *, [, |, ^, (, ), \ ) 出现在 Pattern参数中时必须带双引号。如果 Pattern参数不是简单字符串,通常必须用单引号将整个模式括起来。在诸如 [a-z], 之类的表达式中,-(减号)cml 可根据当前正在整理的序列来指定一个范围。整理序列可以定义等价的类以供在字符范围中使用。如果未指定任何文件,grep会假定为标准输入。

    2.2、grep正则表达式元字符集(基本集)

    ^  锚定行的开始 如:'^grep'匹配所有以grep开头的行。

    $  锚定行的结束 如:'grep$'匹配所有以grep结尾的行。

    .   匹配一个非换行符的字符 如:'gr.p'匹配gr后接一个任意字符,然后是p。

    *  匹配零个或多个先前字符 如:' *grep'匹配所有一个或多个空格后紧跟grep的行。 .*一起用代表任意字符

    [] 匹配一个指定范围内的字符,如'[Gg]rep'匹配Grep和grep。

    [^]  匹配一个不在指定范围内的字符,如:'[^A-FH-Z]rep'匹配不包含A-F和H-Z的一个字母开头,紧跟rep的行。

    \(..\)  标记匹配字符,如:'\(love\)',love被标记为1。

    \<  锚定单词的开始,如:'\<grep'匹配包含以grep开头的单词的行。

    \>  锚定单词的结束,如'grep\>'匹配包含以grep结尾的单词的行。

    x\{m\} 连续重复字符x,m次,如:'o\{5\}'匹配包含连续5个o的行。

    x\{m,\} 连续重复字符x,至少m次,如:'o\{5,\}'匹配至少连续有5个o的行。

    x\{m,n\} 连续重复字符x,至少m次,不多于n次,如:'o\{5,10\}'匹配连续5--10个o的行。

    \w  匹配一个文字和数字字符,也就是[A-Za-z0-9],如:'G\w*p'匹配以G后跟零个或多个文字或数字字符,然后是p。

    \W  w的反置形式,匹配一个非单词字符,如点号句号等。\W*则可匹配多个。

    \b  单词锁定符,如: '\bgrep\b'只匹配grep,即只能是grep这个单词,两边均为空格。

    2.3、grep命令的常用选项及实例

    -?

    同时显示匹配行上下的?行,如:grep -2 pattern filename同时显示匹配行的上下2行。

    -b,--byte-offset

    打印匹配行前面打印该行所在的块号码。

    -c,--count

    只打印匹配的行数,不显示匹配的内容。

    -f File,--file=File

    从文件中提取模板。空文件中包含0个模板,所以什么都不匹配。

    -h,--no-filename

    当搜索多个文件时,不显示匹配文件名前缀。

    -i,--ignore-case

    忽略大小写差别。

    -q,--quiet

    取消显示,只返回退出状态。0则表示找到了匹配的行。

    -l,--files-with-matches

    打印匹配模板的文件清单。

    -L,--files-without-match

    打印不匹配模板的文件清单。

    -n,--line-number

    在匹配的行前面打印行号。

    -s,--silent

    不显示关于不存在或者无法读取文件的错误信息。

    -v,--revert-match

    反检索,只显示不匹配的行。

    -w,--word-regexp

    如果被\<和\>引用,就把表达式做为一个单词搜索。

    -V,--version

    显示软件版本信息。

    =====

    ls -l | grep '^a' 通过管道过滤ls -l输出的内容,只显示以a开头的行。

    grep 'test' d* 显示所有以d开头的文件中包含test的行。

    grep 'test' aa bb cc 显示在aa,bb,cc文件中匹配test的行。

    grep '[a-z]' aa 显示所有包含每个字符串至少有5个连续小写字符的字符串的行。

    grep 'w(es)t.*' aa 如果west被匹配,则es就被存储到内存中,并标记为1,然后搜索任意个字符(.*),这些字符后面紧跟着另外一个es(),找到就显示该行。如果用egrep或grep -E,就不用""号进行转义,直接写成'w(es)t.*'就可以了。

    grep -i pattern files :不区分大小写地搜索。默认情况区分大小写

    grep -l pattern files :只列出匹配的文件名,

    grep -L pattern files :列出不匹配的文件名,

    grep -w pattern files :只匹配整个单词,而不是字符串的一部分(如匹配‘magic’,而不是‘magical’),

    grep -C number pattern files :匹配的上下文分别显示[number]行,

    grep pattern1 | pattern2 files :显示匹配 pattern1 或 pattern2 的行,

    grep pattern1 files | grep pattern2 :显示既匹配 pattern1 又匹配 pattern2 的行。

     

    参考文献:


<think>我们正在介绍Linux常用命令find, grep, sed, awk, man, which, env。每个命令将包括: 1. 命令简介 2. 基本语法 3. 常用选项和参数 4. 使用场景举例 5. 注意事项(如有) 注意:根据引用[1],不同系统(如BSD和GNU)的命令可能有差异,我们以GNU版本(Linux常见)为主。 首先,我们列出这些命令的简要说明: - `find`: 在目录树中查找文件并执行操作 - `grep`: 在文件中搜索匹配模式的行 - `sed`: 流编辑器,用于文本转换 - `awk`: 强大的文本处理工具,也可用于数据提取和报告生成 - `man`: 查看命令的手册页 - `which`: 定位命令的完整路径 - `env`: 查看环境变量或设置临时环境运行程序 下面逐个详细介绍。 ### 1. `find` 命令 **简介**:在指定目录下查找文件,支持按名称、类型、时间、权限等属性搜索,并可对查找到的文件执行操作。 **基本语法**: ```bash find [路径] [表达式] ``` **常用选项**: - `-name`: 按文件名匹配(支持通配符) - `-type`: 按文件类型(f:普通文件, d:目录, l:符号链接等) - `-mtime`: 按修改时间(天数,+n表示n天前,-n表示n天内) - `-exec`: 对查找到的文件执行命令(用`{}`代表文件名,命令以`\;`结束) - `-size`: 按文件大小(如`+1M`表示大于1MB) **使用场景**: 1. 查找当前目录下所有`.txt`文件: ```bash find . -name "*.txt" ``` 2. 查找/home目录下大于1MB的文件并列出详细信息: ```bash find /home -size +1M -exec ls -l {} \; ``` 3. 删除/tmp目录下7天前的临时文件: ```bash find /tmp -type f -mtime +7 -exec rm {} \; ``` **注意事项**: - 使用通配符(如`*`)时,建议用引号括起模式(如`"*.txt"`),避免shell提前展开。 - 使用`-exec`时,`{}`和`\;`是固定格式,不可省略。 ### 2. `grep` 命令 **简介**:在文件中搜索匹配指定模式的行,支持正则表达式。 **基本语法**: ```bash grep [选项] 模式 [文件...] ``` **常用选项**: - `-i`: 忽略大小写 - `-r` 或 `-R`: 递归搜索目录 - `-n`: 显示匹配行的行号 - `-v`: 反向匹配(显示不包含模式的行) - `-E`: 使用扩展正则表达式(等同于`egrep`) **使用场景**: 1. 在当前目录所有文件中搜索包含`error`的行(忽略大小写): ```bash grep -ri "error" . ``` 2. 查找`/etc/passwd`中不含`/bin/bash`的行(即非bash用户): ```bash grep -v "/bin/bash" /etc/passwd ``` 3. 使用正则表达式匹配IP地址(需要`-E`): ```bash echo "192.168.1.1" | grep -E '[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}' ``` **注意事项**: - 模式中若包含特殊字符(如`$`, `*`),需用单引号括起。 - 递归搜索时,`-r`和`-R`在大多数Linux发行版中行为相同,但在某些系统(如macOS)中`-R`会跟随符号链接。 ### 3. `sed` 命令 **简介**:流编辑器,用于对输入流(文件或管道)进行文本转换(如替换、删除、插入)。 **基本语法**: ```bash sed [选项] '指令' [输入文件] ``` **常用指令**: - `s/模式/替换/`: 替换匹配模式的文本(可加`g`表示全局替换) - `d`: 删除行 - `p`: 打印行(通常与`-n`选项配合使用) - `a\text`: 在行后追加文本 - `i\text`: 在行前插入文本 **使用场景**: 1. 替换文件中的字符串(原文件不变,输出到屏幕): ```bash sed 's/foo/bar/g' file.txt ``` 2. 直接修改文件(使用`-i`选项): ```bash sed -i 's/foo/bar/g' file.txt ``` 3. 删除空白行: ```bash sed '/^$/d' file.txt ``` **注意事项**: - `-i`选项会直接修改文件,建议先备份或测试无误后再使用。 - 指令中的分隔符`/`可替换为其他字符(如`s|foo|bar|g`),避免与模式中的`/`冲突。 ### 4. `awk` 命令 **简介**:强大的文本处理工具,按行处理,自动分割字段(默认空格分隔),支持编程结构(如条件、循环)。 **基本语法**: ```bash awk '模式 {动作}' [文件] ``` **常用变量**: - `$0`: 整行内容 - `$1`, `$2`, ...: 第1、2个字段 - `NF`: 当前行的字段数 - `NR`: 当前行号 - `FS`: 输入字段分隔符(默认为空格) - `OFS`: 输出字段分隔符(默认为空格) **使用场景**: 1. 打印文件每行的第一个字段(如`/etc/passwd`的用户名): ```bash awk -F: '{print $1}' /etc/passwd ``` 2. 统计文件行数: ```bash awk 'END {print NR}' file.txt ``` 3. 计算第1列数字之和: ```bash awk '{sum+=$1} END {print sum}' data.txt ``` **注意事项**: - 指定分隔符用`-F`(如`-F:`表示冒号分隔)。 - 引用变量时无需加`$`(如`NR`),而字段需要(如`$1`)。 ### 5. `man` 命令 **简介**:查看命令、函数或配置文件的手册页(manual pages)。 **基本语法**: ```bash man [章节] 名称 ``` **常用章节**: - 1: 用户命令 - 2: 系统调用 - 3: 库函数 - 5: 文件格式(如配置文件) - 8: 系统管理命令 **使用场景**: 1. 查看`ls`命令的用法: ```bash man ls ``` 2. 查看`open`系统调用的文档(需指定章节): ```bash man 2 open ``` **注意事项**: - 按`q`退出手册页。 - 若名称同时存在于多个章节(如`printf`命令和函数),可用`man 1 printf`和`man 3 printf`区分。 ### 6. `which` 命令 **简介**:定位命令的完整路径(在`$PATH`环境变量中查找)。 **基本语法**: ```bash which 命令名 ``` **使用场景**: 1. 查看`ls`命令的路径: ```bash which ls # 输出:/bin/ls ``` 2. 检查命令是否存在: ```bash which some_command > /dev/null && echo "存在" || echo "不存在" ``` **注意事项**: - 仅搜索`$PATH`中的目录,不会查找别名或内置命令(如`cd`)。 ### 7. `env` 命令 **简介**:查看当前环境变量,或设置临时环境运行程序。 **基本语法**: ```bash env [选项] [变量=值]... [命令] ``` **使用场景**: 1. 显示所有环境变量: ```bash env ``` 2. 临时修改环境变量运行程序(如设置`LANG`): ```bash env LANG=C date ``` 3. 清除所有环境变量后运行程序(`-i`选项): ```bash env -i /path/to/program ``` **注意事项**: - 临时设置的环境变量仅影响后续执行的命令,不影响当前shell环境。 ### 总结 以上命令是Linux系统管理、文本处理和日常使用的核心工具。熟练掌握它们能极大提高工作效率。注意不同系统(如BSD和GNU)的差异,如引用[1]所述,跨平台脚本需谨慎使用这些命令或考虑Python/Perl替代。 §§相关问题§§ 1. 如何组合使用`find`和`grep`进行复杂搜索? 2. `sed`和`awk`在文本处理中有哪些典型区别? 3. 如何通过`man`手册快速查找特定选项的说明? 4. 在脚本中如何安全地使用`find`的`-exec`选项? 5. `env`命令在脚本开发中的常见用途有哪些?</think>### Linux 常用命令详解 #### 1. `find`:文件搜索工具 **用途**:在目录树中递归搜索文件,支持按名称、类型、时间、权限等条件过滤 **基本语法**: ```bash find [路径] [表达式] ``` **常用场景**: - 按名称搜索:`find /home -name "*.txt"`(查找/home下所有txt文件)[^2] - 按类型搜索:`find . -type d`(查找当前目录所有子目录) - 按时间过滤:`find /var/log -mtime -7`(查找7天内修改的文件) - 结合执行操作:`find ~ -size +10M -exec rm {} \;`(删除大于10MB的文件) **注意**:BSD和GNU版本参数有差异,跨平台需谨慎[^1] --- #### 2. `grep`:文本搜索工具 **用途**:在文件或输入流中匹配正则表达式 **基本语法**: ```bash grep [选项] 模式 [文件] ``` **常用场景**: - 基础搜索:`grep "error" /var/log/syslog`(搜索包含error的行) - 递归搜索:`grep -r "TODO" src/`(递归搜索源码目录) - 显示行号:`grep -n "pattern" file`(显示匹配行号) - 反向过滤:`grep -v "#" config.conf`(过滤注释行) **特殊技巧**: ```bash ps aux | grep "[n]ginx" # 精确匹配进程(避免匹配grep自身) ``` --- #### 3. `sed`:流编辑器 **用途**:对文本流进行替换、删除、插入等操作 **基本语法**: ```bash sed [选项] '指令' 文件 ``` **核心操作**: | 指令 | 作用 | 示例 | |----------|--------------------------|-------------------------------| | `s/old/new/` | 替换文本 | `sed 's/foo/bar/g' file` | | `/pattern/d` | 删除匹配行 | `sed '/^#/d' config` | | `5i\text` | 在第5行前插入文本 | `sed '3i\# New Line' file` | **典型场景**: - 批量替换:`sed -i.bak 's/old/new/g' *.txt`(备份并替换) - 删除空行:`sed '/^$/d' input.txt > output.txt` --- #### 4. `awk`:文本处理语言 **用途**:字段提取、数据统计、报告生成 **基本语法**: ```bash awk '模式 {动作}' 文件 ``` **核心概念**: - `$0`:整行内容 - `$1, $2...`:第1、2个字段 - `NR`:行号,`NF`:字段数 **常用场景**: - 提取字段:`awk -F: '{print $1}' /etc/passwd`(输出用户名) - 条件过滤:`awk '$3 > 1000 {print $0}' data.csv`(过滤第三列大于1000的行) - 数据统计: ```bash awk '{sum+=$1} END {print "Average:", sum/NR}' numbers.txt ``` --- #### 5. `man`:手册查看 **用途**:查看命令/系统调用的文档 **基本语法**: ```bash man [章节] 命令名 ``` **手册章节**: 1. 用户命令 2. 系统调用 3. 库函数 **技巧**: - `man -k keyword`:搜索相关手册(如`man -k "socket"`) - 导航:空格翻页,`/pattern`搜索,`q`退出 --- #### 6. `which`:命令定位 **用途**:查找命令的绝对路径 **示例**: ```bash $ which python /usr/bin/python # 显示第一个匹配路径 ``` **注意**:仅搜索`$PATH`变量中的路径 --- #### 7. `env`:环境管理 **用途**:查看/设置环境变量,临时修改环境执行命令 **常用操作**: - 查看所有环境变量:`env` - 临时修改变量: ```bash env LANG=C python script.py # 临时使用C语言环境执行 ``` - 清空环境执行:`env -i command`(无继承环境) --- ### 命令组合实战 **场景**:统计nginx日志中404错误的IP分布 ```bash grep " 404 " access.log | awk '{print $1}' | sort | uniq -c | sort -nr ``` 1. `grep`过滤404错误 2. `awk`提取IP地址(第1列) 3. `sort`排序 4. `uniq -c`统计重复次数 5. `sort -nr`按次数倒序排列 --- ### 注意事项 1. BSD(如MacOS)与GNU命令存在差异,跨平台脚本建议测试或使用Python/Perl替代[^1] 2. 变量引用用`${var}`避免歧义(如`${var}_suffix`)[^3] 3. 脚本参数处理:`$0`脚本名,`$1`第一个参数,`$#`参数个数[^2]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值