一、顯示文本
創(chuàng)新互聯(lián)公司主要從事成都做網(wǎng)站、網(wǎng)站制作、網(wǎng)頁設(shè)計、企業(yè)做網(wǎng)站、公司建網(wǎng)站等業(yè)務(wù)。立足成都服務(wù)赤壁,10多年網(wǎng)站建設(shè)經(jīng)驗,價格優(yōu)惠、服務(wù)專業(yè),歡迎來電咨詢建站服務(wù):18980820575(一)more命令
1.語法格式
格式:more??[選項]??filename
功能:讀取filename中的內(nèi)容,逐屏往下翻頁顯示,按h顯示幫助,按q退出。
2.選項
-d, --silent display help instead of ringing bell
-f, --logical count logical rather than screen lines
-l, --no-pause suppress pause after form feed
-c, --print-over do not scroll, display text and clean line ends
-p, --clean-print do not scroll, clean screen and display text?顯示下一屏之前先清屏
-s, --squeeze squeeze multiple blank lines into one?文件中連續(xù)的空白行壓縮成一個空白行顯示
-u, --plain suppress underlining and bold
-n, --lines
-
+
+/
-h, --help 顯示此幫助
-V, --version 顯示版本
3.參數(shù)
文件名
4.示例
(1)正常用法
more file.txt
顯示file.txt的內(nèi)容
more Test.java file.txt
顯示Test.java和file.txt的內(nèi)容
(2)-s選項
more -s file
連續(xù)的空白行壓縮成一個空白行顯示
(二)less命令
1.語法格式
格式:less??[選項]??filename
功能:依次讀取filename中的內(nèi)容,該命令與more的不同是不僅可以向下翻頁,還可以向上翻頁,使用上下鍵、Enter、空格、pageDown、pageUp可以實現(xiàn)前后翻頁,按h幫助,按q退出。
2.選項
選項太多了
使用less --help查看
3.參數(shù)
文件名
4.示例
(1)正常用法
less Test.java
顯示Test.java的內(nèi)容
(三)cat命令
全稱concatenate,串接的意思
1.語法格式
用法:cat [選項]... [文件]...
連接一個或多個<文件>并輸出到標(biāo)準(zhǔn)輸出。
2.選項
-A, --show-all 等價于 -vET
-b, --number-nonblank 對非空輸出行編號,使 -n 失效
-e 等價于 -vE
-E, --show-ends 在每行行末顯示 "$"
-n, --number 對輸出的所有行編號
-s, --squeeze-blank 不重復(fù)輸出空行
-t 等價于 -vT
-T, --show-tabs 將 TAB 顯示為 ^I
-u (被忽略)
-v, --show-nonprinting 使用 ^ 和 M- 表示法,LFD 和 TAB 字符除外
--help 顯示此幫助信息并退出
--version 顯示版本信息并退出
3.參數(shù)
文件名
-(減號)
4.示例
(1)正常用法
cat Test.java
顯示當(dāng)前目錄下Test.java的內(nèi)容
(2)-n選項
cat -n Test.java
顯示當(dāng)前目錄下Test.java的內(nèi)容,并加上行號
(3)-E, --show-ends 在每行行末顯示 "$"
cat -E Test.java
顯示當(dāng)前目錄下Test.java的內(nèi)容,在每行末加上$
(4)-s, --squeeze-blank 不重復(fù)輸出空行
(5)-v, --show-nonprinting 使用 ^ 和 M- 表示法,LFD 和 TAB 字符除外
(四)od命令
octal dump?逐字節(jié)打印,可以用八進制/十六進制打印
1.語法格式
用法:od [選項]... [文件]...
或:od [-abcdfilosx]... [文件] [[+]偏移量[.][b]]
或:od --traditional [選項]... [文件] [[+]偏移量[.][b] [+][標(biāo)簽][.][b]]
以無歧義的表示方式將<文件>輸出至標(biāo)準(zhǔn)輸出,默認(rèn)為八進制字節(jié)形式。
如果指定了多于一個<文件>,則將它們按照列出的順序連接起來作為輸入。
如果沒有指定文件,或者文件為"-",則從標(biāo)準(zhǔn)輸入讀取。
2.選項
-A, --address-radix=基數(shù) 指定文件偏移量的輸出格式;這里給出的<基數(shù)>
是 [doxn] 其中之一,分別代表十進制、八進制、
十六進制和無基數(shù)
--endian={big|little} 按照指定的字節(jié)序交換輸入字節(jié)
-j, --skip-bytes=字節(jié)數(shù) 處理前先跳過<字節(jié)數(shù)>個輸入字節(jié)
-N, --read-bytes=字節(jié)數(shù) 最多讀取<字節(jié)數(shù)>個輸入的字節(jié)
-S 字節(jié)數(shù), --strings[=字節(jié)數(shù)] 輸出至少包含<字節(jié)數(shù)>個可打印字符的字符串;
如未指定<字節(jié)數(shù)>,則默認(rèn)為 3
-t, --format=類型 選擇一個或多個輸出格式
-v, --output-duplicates 不使用 "*" 字符代替被省略的行
-w[字節(jié)數(shù)], --width[=字節(jié)數(shù)] 每一行輸出<字節(jié)數(shù)>個字節(jié);
如未指定<字節(jié)數(shù)>,則默認(rèn)為 32
--traditional 接受以上面第三種格式提供的參數(shù)
--help 顯示此幫助信息并退出
--version 顯示版本信息并退出
傳統(tǒng)的格式說明符可以混合使用,不同的格式可以累加:
-a 即 -t a, 輸出字符的名稱,忽略最高位
-b 即 -t o1,輸出八進制字節(jié)
-c 即 -t c, 輸出可打印字符或者使用反斜杠轉(zhuǎn)義
-d 即 -t u2,輸出無符號十進制數(shù),兩個字節(jié)為一個輸出單位
-f 即 -t fF,輸出浮點數(shù)
-i 即 -t dl,輸出十進制整型 (int)
-l 即 -t dL,輸出十進制長整型 (long)
-o 即 -t o2,輸出八進制數(shù),兩個字節(jié)為一個輸出單位
-s 即 -t d2,輸出十進制數(shù),兩個字節(jié)為一個輸出單位
-x 即 -t x2,輸出十六進制數(shù),兩個字節(jié)為一個輸出單位
<類型>是由下面一種或多種說明符組成的:
a 字符名稱,忽略最高位
c 可打印字符或者使用反斜杠轉(zhuǎn)義
d[大小] 有符號十進制數(shù),每個整數(shù)占<大小>個字節(jié)
f[大小] 浮點數(shù),每個浮點數(shù)占<大小>個字節(jié)
o[大小] 八進制數(shù),每個整數(shù)占<大小>個字節(jié)
u[大小] 無符號十進制數(shù),每個整數(shù)占<大小>個字節(jié)
x[大小] 十六進制數(shù),每個整數(shù)占<大小>個字節(jié)
<大小>是一個數(shù)字。如果<類型>是 [doux] 之一,<大小>也可以是:
C 代表 sizeof(char)、S 代表 sizeof(short)、I 代表 sizeof(int),
或 L 代表 sizeof(long)。如果<類型>是 f,<大小>也可以是:
F 代表 sizeof(float)、D 代表 sizeof(double),或 L 代表 sizeof(long double)。
在任何類型后面加上 "z" 后綴,將會在每個輸出行的末尾顯示可打印字符。
如果<字節(jié)數(shù)>有 "0x" 或 "0X" 前綴,則將其視為十六進制數(shù)。
<字節(jié)數(shù)>可以有乘數(shù)后綴:
b 512
KB 1000
K 1024
MB 1000*1000
M 1024*1024
G、T、P、E、Z、Y 以此類推。
也可以使用二進制前綴:KiB=K、MiB=M,以此類推。
3.參數(shù)
文件名
-
4.示例
(1)-t選項
下列方式可以以16進制顯示一個字符串的編碼。
echo abcdABCD | od -t x1
0000000 61 62 63 64 41 42 43 44 0a
0000011
(五)head命令
1.語法格式
用法:head [選項]... [文件]...
將每個<文件>的前 10 行輸出到標(biāo)準(zhǔn)輸出。
如果指定了多個<文件>,在輸出每個文件之前先輸出文件名作為頭部。
如果沒有指定<文件>,或者<文件>為 "-",則從標(biāo)準(zhǔn)輸入讀取。
2.選項
-c, --bytes=[-]數(shù)字 顯示每個文件的前<數(shù)字>字節(jié)內(nèi)容;
如果數(shù)字前附加 "-" 字符,則顯示每個文件
除了最后<數(shù)字>字節(jié)以外的全部內(nèi)容
-n, --lines=[-]數(shù)字 顯示每個文件的前<數(shù)字>行內(nèi)容而非前 10 行內(nèi)容;
如果數(shù)字前附加 "-" 字符,則顯示每個文件
除了最后<數(shù)字>行以外的全部內(nèi)容
-q, --quiet, --silent 不打印文件名作為頭部
-v, --verbose 總是打印文件名作為頭部
-z, --zero-terminated 以 NUL 空字符而非換行符作為行分隔符
--help 顯示此幫助信息并退出
--version 顯示版本信息并退出
3.參數(shù)
文件名
-
4.示例
(1)正常用法
head test
顯示test的前10行
(2)-n選項
head -3 Test.java
顯示Test.java的前3行
(六)tail命令
1.語法格式
用法:tail [選項]... [文件]...
將每個<文件>的最后 10 行輸出到標(biāo)準(zhǔn)輸出。
如果指定了多個<文件>,程序會在每個文件的開頭添加文件名作為頭部。
如果沒有指定<文件>,或者<文件>為 "-",則從標(biāo)準(zhǔn)輸入讀取。
2.選項
-c, --bytes=[+]數(shù)字 輸出最后<數(shù)字>個字節(jié);或者使用 -c +數(shù)字 以輸出
每個文件第<數(shù)字>個字節(jié)起的全部內(nèi)容
-f, --follow[={name|descriptor}]
隨文件增長即時輸出新增數(shù)據(jù);
若未指定選項參數(shù),則默認(rèn)使用 "descriptor"
-F 同 --follow=name --retry
-n, --lines=[+]數(shù)字 輸出最后<數(shù)字>行,而不是默認(rèn)的最后 10 行;或者
使用 -n +數(shù)字 輸出每個文件第<數(shù)字>行起的全部內(nèi)容
--max-unchanged-stats=N
和 --follow=name 同時使用時, 如果一個<文件>在 N 次
(默認(rèn)為 5 次)迭代后沒有改變大小,則重新打開它,
以確認(rèn)它是否已被刪除或重命名(對于輪轉(zhuǎn) (rotated)
日志文件而言,這種情況很常見);
如果內(nèi)核支持 inotify,則此選項通常沒有用處
--pid=PID 和 -f 同時使用時,在進程號為 PID 的進程結(jié)束后終止執(zhí)行
-q, --quiet, --silent 不輸出含有文件名的頭
--retry 即使目標(biāo)文件無法訪問,仍然不斷嘗試打開
-s, --sleep-interval=N 和 -f 同時使用時,在兩次迭代之間睡眠約 N 秒
(默認(rèn) 1.0 秒)
內(nèi)核支持 inotify 且使用了 --pid=P 時,每 N 秒
至少檢查一次進程 P
-v, --verbose 總是輸出含有文件名的頭
-z, --zero-terminated 以 NUL 空字符而非換行符作為行分隔符
--help 顯示此幫助信息并退出
3.參數(shù)
文件名
-
4.示例
(1)正常用法
tail test
顯示test后10行
(2)-n選項
tail -n3?Test.java
tail -3 Test.java
顯示Test.java的最后3行
(七)tee命令
1.語法格式
用法:tee [選項]... [文件]...
將標(biāo)準(zhǔn)輸入復(fù)制到每個<文件>,并同時輸出到標(biāo)準(zhǔn)輸出。
2.選項
-a, --append 追加到<文件>,而不是覆蓋
-i, --ignore-interrupts 忽略中斷信號
-p 寫入到非管道的對象出錯時,輸出診斷信息
--output-error[=模式] 設(shè)置寫入出錯時的行為。見下面<模式>部分
--help 顯示此幫助信息并退出
--version 顯示版本信息并退出
<模式>決定了寫入到輸出對象時出錯后的行為:
warn 寫入到任一輸出對象時出錯,則輸出診斷信息
warn-nopipe 寫入到任一非管道的輸出對象時出錯,則輸出診斷信息
exit 寫入到任一輸出對象時出錯,則退出
exit-nopipe 寫入到任一非管道的輸出對象時出錯,則退出
-p 選項的默認(rèn)<模式>是 "warn-nopipe"。
未指定 --output-error 選項時,默認(rèn)的操作是寫入到管道出錯時立刻退出,
寫入到非管道對象出錯時輸出診斷信息。
3.參數(shù)
文件名
4.示例
(1)正常用法
echo 'hello world' | tee?xx.txt
將hello world打印終端中,同時保存到xx.txt文件中。
(八)uniq命令
篩選文件中的重復(fù)行
1.語法格式
用法:uniq [選項]... [輸入文件 [輸出文件]]
從<輸入文件>(或標(biāo)準(zhǔn)輸入)中過濾內(nèi)容相同的相鄰的行,
并寫到<輸出文件>(或標(biāo)準(zhǔn)輸出)。
不帶選項時,內(nèi)容相同的行將僅輸出一次。
2.選項
長選項的必選參數(shù)對于短選項也是必選的。
-c, --count 在每行之前加上該行的重復(fù)次數(shù)作為前綴
-d, --repeated 只輸出重復(fù)的行,每組重復(fù)的行輸出一次
-D 輸出所有重復(fù)的行
--all-repeated[=方法] 類似 -D,但支持在每組重復(fù)的行之間添加一行空行;
方法={none(默認(rèn)),prepend,separate}
-f, --skip-fields=N 不要比較前 N 個字段
--group[=方法] 分組輸出所有項目,每組之間用空行分隔;
方法={separate(默認(rèn)),prepend,append,both}
-i, --ignore-case 比較時忽略大小寫
-s, --skip-chars=N 不要比較前 N 個字符
-u, --unique 只輸出不重復(fù)(內(nèi)容唯一)的行
-z, --zero-terminated 以 NUL 空字符而非換行符作為行分隔符
-w, --check-chars=N 每行最多比較 N 個字符
--help 顯示此幫助信息并退出
--version 顯示版本信息并退出
字段指的是空白字符(通常是空格和/或制表符)的序列,后跟非空白字符的序列。
程序?qū)⑾忍^字段 (--skip-fields),后跳過字符 (--skip-chars)。
注意:除非重復(fù)的行是相鄰的,否則 "uniq" 將無法檢測到它們。
您可能需要事先對輸入進行排序,或使用 "sort -u" 而無需接著使用 "uniq"。
3.參數(shù)
輸入文件
輸出文件
4.示例
(1)正常使用
uniq test
二、增加文本
使用重定向>>追加文本
也可以使用sed命令實現(xiàn)插入文本
三、刪除文本
一般使用sed命令實現(xiàn)刪除文本
四、查找文本
(一)grep命令
grep
五、替換文本
(一)tr命令
tr string1 string2: 將string1中包含的字符,替換為string2中對應(yīng)的字符,然后再拷貝到標(biāo)準(zhǔn)輸出。
1.語法格式
用法:tr [選項]... 字符串1 [字符串2]
從標(biāo)準(zhǔn)輸入中替換、縮減和/或刪除字符,并將結(jié)果寫到標(biāo)準(zhǔn)輸出。
<字符串1>和<字符串2>用于指定字符數(shù)組<數(shù)組1>和<數(shù)組2>,這兩個
<數(shù)組>將控制程序的行為。
2.選項
-c, -C, --complement 使用<數(shù)組1>的補集
-d, --delete 刪除<數(shù)組1>中的字符,不進行替換
-s, --squeeze-repeats 將最后一個<數(shù)組>中任何一個字符多次重復(fù)
形成的序列,縮減為僅有一個這個字符
-t, --truncate-set1 先將<數(shù)組1>截斷為和<數(shù)組2>長度相同
--help 顯示此幫助信息并退出
--version 顯示版本信息并退出
3.參數(shù)
指定的<數(shù)組>是字符串。大多數(shù)字符串僅表示該字符串本身??山忉尩男蛄腥缦拢?br />
\NNN 值為 NNN(1 至 3 位八進制數(shù))的字符
\\ 反斜杠
響鈴字符 BEL
\b 退格
\f 換頁
\n 換行
\r 回車
\t 水平制表符
\v 垂直制表符
字符1-字符2 從<字符1>到<字符2>的所有字符,按升序排列
[字符*] 在<數(shù)組2>中不斷重復(fù)<字符>,直到<數(shù)組2>的長度等于<數(shù)組1>
[字符*個數(shù)]<個數(shù)>個<字符>,若<個數(shù)>以 0 開頭,則視為八進制數(shù)
[:alnum:] 所有的字母和數(shù)字
[:alpha:] 所有的字母
[:blank:] 所有的水平空白字符
[:cntrl:] 所有的控制字符
[:digit:] 所有的數(shù)字
[:graph:] 所有的可打印字符,不包括空格
[:lower:] 所有的小寫字母
[:print:] 所有的可打印字符,包括空格
[:punct:] 所有的標(biāo)點符號
[:space:] 所有的水平或垂直空白字符
[:upper:] 所有的大寫字母
[:xdigit:] 所有的十六進制數(shù)字
[=字符=] 所有和<字符>等價的字符
僅在同時指定了<字符串1>和<字符串2>,且沒有使用 -d 選項時才會進行替換。
僅在替換時才可以使用 -t 選項。如果需要,將重復(fù)<數(shù)組2>的最后一個字符,
使<數(shù)組2>和<數(shù)組1>等長。<數(shù)組2>中多余的字符將被忽略。字符類展開的
順序是未指定的;在進行替換操作時,可以成對使用 [:lower:] 和 [:upper:],
以表示大小寫轉(zhuǎn)換??s減操作將在替換或刪除完成之后進行。
4.示例
(1)正常用法
echo abcdABCD | tr aBc AbC
# 輸出結(jié)果如下:
AbCdAbCD
(2)用 [ ]指定一個集合
# 將小寫字母轉(zhuǎn)換為大寫字母
echo abcdABCD | tr '[a-z]'? '[A-Z]'
# 輸出結(jié)果如下:
ABCDABCD
(3)用 \加上三個八進制數(shù)字(類似C語言)表示一個字符
# 將%替換為換行符(八進制012),注意不要漏掉必須的單引號
cat file1 | tr % '\012'
(二)sed命令
sed
(三)awk命令
awk
六、文本統(tǒng)計
(一)wc命令
1.語法格式
用法:wc [選項]... [文件]...
或:wc [選項]... --files0-from=F
打印每個<文件>的換行符、單詞和字節(jié)計數(shù);如果指定了多個<文件>,
則還會打印一個 "總計" 行。此處的 "單詞" 是指由空白字符分隔的
長度大于零的字符序列。
如果沒有指定<文件>,或者<文件>為 "-",則從標(biāo)準(zhǔn)輸入讀取。
2.選項
可使用以下選項選擇輸出哪些種類的計數(shù)。輸出總是遵循以下順序:
換行符數(shù)、單詞數(shù)、字符數(shù)、字節(jié)數(shù)、最長行的長度。
-c, --bytes 輸出字節(jié)數(shù)
-m, --chars 輸出字符數(shù)
-l, --lines 輸出換行符數(shù)
--files0-from=F 從文件 F 中讀取以 NUL 空字符分隔的文件名作為
輸入文件的名稱;
如果 F 是 "-",則從標(biāo)準(zhǔn)輸入讀取文件名
-L, --max-line-length 輸出最長行的長度
-w, --words 輸出單詞數(shù)
--help 顯示此幫助信息并退出
--version 顯示版本信息并退出
3.參數(shù)
文件名
4.示例
(1)正常用法
wc Test.java
輸出Test.java的換行符、單詞和字節(jié)計數(shù)
(2)-l選項,只顯示行數(shù)
ps -ef | wc -l
顯示系統(tǒng)有多少個進程
who | wc -l
顯示當(dāng)前有多少個用戶登陸
(3)-w, --words 輸出單詞數(shù)
wc -w Test.java
統(tǒng)計Test.java的單詞數(shù)
(4)-m, --chars 輸出字符數(shù)
(5)-c, --bytes 輸出字節(jié)數(shù)
七、文本排序
(一)sort命令
1.語法格式
用法:sort [選項]... [文件]...
或:sort [選項]... --files0-from=F
連接所有<文件>,然后排序,并將結(jié)果寫到標(biāo)準(zhǔn)輸出。
如果沒有指定<文件>,或者<文件>為 "-",則從標(biāo)準(zhǔn)輸入讀取。
2.選項
長選項的必選參數(shù)對于短選項也是必選的。
排序選項:
-b, --ignore-leading-blanks 忽略前導(dǎo)的空白字符
-d, --dictionary-order 只考慮空白字符、字母和數(shù)字
-f, --ignore-case 忽略大小寫
-g, --general-numeric-sort 對一般化的數(shù)字進行排序
-i, --ignore-nonprinting 只考慮可打印字符
-M, --month-sort 對月份進行排序:(未知)< "1月"< ...< "12月"
LC_ALL=C 時:(未知)< "JAN"< ...< "DEC"
-h, --human-numeric-sort 對可讀性較好的數(shù)字(例如:2K 1G)進行排序
-n, --numeric-sort 對數(shù)字進行排序
-R, --random-sort 隨機排序,但是相等的鍵會排序到一起。參見 shuf(1)
--random-source=文件 從<文件>中獲得隨機字節(jié)
-r, --reverse 逆序輸出排序結(jié)果
--sort=關(guān)鍵字 按照<關(guān)鍵字>指定的方式排序:
general-numeric 同 -g、human-numeric 同 -h、
month 同 -M、numeric 同 -n、random 同 -R、
version 同 -V
-V, --version-sort 對文本中的數(shù)字(或版本號)進行自然排序
3.參數(shù)
文件名
4.示例
(1)-n:? 按照數(shù)值大小排序,而不是按照字符串比較規(guī)則。
比如:123與67:
如果按照字符串排序的話,67比123大;
如果按照數(shù)字值排序的話,123比67大
八、路徑名處理
(一)basename命令
去掉路徑名的目錄部分
1.語法格式
用法:basename 名稱 [后綴]
或:basename 選項... 名稱...
去掉前導(dǎo)的目錄部分后打印<名稱>。
如果指定的話,還會去掉末尾的<后綴>。
2.選項
長選項的必選參數(shù)對于短選項也是必選的。
-a, --multiple 支持接受多個參數(shù),并把每個參數(shù)都視作給定的<名稱>
-s, --suffix=后綴 移除末尾的<后綴>;隱含啟用 -a 選項
-z, --zero 以 NUL 空字符而非換行符來結(jié)束每一個輸出行
--help 顯示此幫助信息并退出
--version 顯示版本信息并退出
3.參數(shù)
文件路徑名
文件后綴
4.示例用法
(1)正常用法
basename /usr/bin/sort
輸出:
sort
basename /home/mikel/bin/bvurns.sh
輸出:
bvurns.sh
(2)帶后綴參數(shù)
basename /home/mikel/bin/bvurns.sh .sh
輸出:
bvurns
(3)-s選項
basename -s .h include/stdio.h
輸出:
stdio
(4)-a選項
basename -a any/str1 any/str2
輸出:
str1
str2
(二)dirname命令
只保留目錄部分
1.語法格式
用法:dirname [選項] 名稱...
去掉<名稱>中最后一個非 "/" 部分,以及末尾的 "/",然后輸出;
如果名稱中不包含 "/",則輸出 "."(表示當(dāng)前目錄)。
2.選項
-z, --zero 以 NUL 空字符而非換行符結(jié)束每個輸出行
--help 顯示此幫助信息并退出
--version 顯示版本信息并退出
3.參數(shù)
路徑名
4.示例用法
(1)正常用法
dirname /usr/bin/
輸出:
/usr
dirname dir1/str dir2/str
輸出:
dir1
dir2
dirname stdio.h
輸出:
.
(三)綜合運用舉例
把大小大于100000字節(jié)的文件分割成多個小文件,然后把大文件名加上huge.前綴。(假設(shè)文件名中沒有空格)
1.第一種寫法
for path in `find /home/you -type f -size +100000c -print`; do
cd `dirname $path` || exit
filename=`basename $path`
split $filename $filename.
mv -i $filename huge.$filename
done
2.第二種寫法
find /home/you -type f -size +100000c -print | while read path; do
cd `dirname $path` || exit
filename=`basename $path`
split $filename $filename.
mv -i $filename huge.$filename
done
你是否還在尋找穩(wěn)定的海外服務(wù)器提供商?創(chuàng)新互聯(lián)www.cdcxhl.cn海外機房具備T級流量清洗系統(tǒng)配攻擊溯源,準(zhǔn)確流量調(diào)度確保服務(wù)器高可用性,企業(yè)級服務(wù)器適合批量采購,新人活動首月15元起,快前往官網(wǎng)查看詳情吧