版本記錄
版本號 | 時間 |
---|---|
V1.0 | 2017.08.22 |
前言
前面我簡單的寫了些NSString的初始化,寫了幾篇,都不難,但是可以對新手有一定的小幫助,對于大神級人物可以略過這幾篇,NSString本來就沒有難的,都是細枝末節,忘記了查一下就會了,沒有技術難點,下面我們繼續~~~
1. NSString簡單細說(一)—— NSString整體架構
2. NSString簡單細說(二)—— NSString的初始化
3. NSString簡單細說(三)—— NSString初始化
4. NSString簡單細說(四)—— 從URL初始化
5. NSString簡單細說(五)—— 向文件或者URL寫入
6. NSString簡單細說(六)—— 字符串的長度
7. NSString簡單細說(七)—— 與C字符串的轉化
8. NSString簡單細說(八)—— 識別和比較字符串
9. NSString簡單細說(九)—— 字符串的合并
10. NSString簡單細說(十)—— 字符串的分解
11. NSString簡單細說(十一)—— 字符串的查找
12. NSString簡單細說(十二)—— 字符串的替換
13. NSString簡單細說(十三)—— 字符串的分行和分段
14. NSString簡單細說(十四)—— 字符串位置的計算
15. NSString簡單細說(十五)—— 字符串轉化為propertyList
16. NSString簡單細說(十六)—— 畫字符串
17. NSString簡單細說(十七)—— 字符串的折疊和前綴
18. NSString簡單細說(十八)—— 字符串中大小寫子母的變換
19. NSString簡單細說(十九)—— 根據映射獲取字符串
20. NSString簡單細說(二十)—— 獲取字符串的數值
21. NSString簡單細說(二十一)—— 字符串與編碼
22. NSString簡單細說(二十二)—— 與路徑相關(一)
23. NSString簡單細說(二十三)—— 與路徑相關(二)
23. NSString簡單細說(二十三)—— 與路徑相關(二)
24. NSString簡單細說(二十四)—— 與URL相關
這一篇我們說一下語言標簽與分析。
一、 - (void)enumerateLinguisticTagsInRange:(NSRange)range scheme:(NSString *)tagScheme options:(NSLinguisticTaggerOptions)opts orthography:(NSOrthography *)orthography usingBlock:(void (^)(NSString *tag, NSRange tokenRange, NSRange sentenceRange, BOOL *stop))block;
我們看一下這個方法的作用:通過枚舉字符串的特定范圍對指定的字符串進行語言分析,為Block提供位置標簽。
下面我們看一下參數:
-
range
:要分析字符串的位置區間。 -
tagScheme
:要使用的標簽方案。 請參閱語言標簽方案支持值。 -
NSLinguisticTaggerOptions
:使用的語言標簽選項。 請參見NSLinguisticTaggerOptions的常量。 這些常數可以使用C位按OR運算符進行組合。這個是一個枚舉,具體參見下面:
/* For NSLinguisticTagSchemeTokenType, NSLinguisticTagSchemeLexicalClass, NSLinguisticTagSchemeNameType, and NSLinguisticTagSchemeNameTypeOrLexicalClass, tags will be taken from the lists above (clients may use == comparison). Tags for NSLinguisticTagSchemeLemma are lemmas from the language. Tags for NSLinguisticTagSchemeLanguage are standard language abbreviations. Tags for NSLinguisticTagSchemeScript are standard script abbreviations.
*/
/* Options arguments of type NSLinguisticTaggerOptions may include the following flags, which allow clients interested only in certain general types of tokens to specify that tokens of other types should be omitted from the returned results. */
typedef NS_OPTIONS(NSUInteger, NSLinguisticTaggerOptions) { /* Any combination of options from the enumeration. */
NSLinguisticTaggerOmitWords = 1 << 0, /* Omit tokens of type NSLinguisticTagWord. */
NSLinguisticTaggerOmitPunctuation = 1 << 1, /* Omit tokens of type NSLinguisticTagPunctuation. */
NSLinguisticTaggerOmitWhitespace = 1 << 2, /* Omit tokens of type NSLinguisticTagWhitespace. */
NSLinguisticTaggerOmitOther = 1 << 3, /* Omit tokens of type NSLinguisticTagOther. */
NSLinguisticTaggerJoinNames = 1 << 4 /* Join tokens of tag scheme NSLinguisticTagSchemeNameType. */
};
-
orthography
:字符串的正字法。 如果沒有,語言標簽將嘗試從字符串內容中確定正字法。 -
block
:block中包含很多其他參數。-
tag
:標記的標簽方案。 opts參數指定所在的標記器選項的類型。 -
tokenRange
:匹配標簽方案的字符串的范圍。 -
sentenceRange
:找到token的句子的范圍。 -
stop
:對布爾值的引用。 該塊可以將該值設置為YES,以停止數組的進一步處理。 停止參數是一個out-only
參數。 您應該只在Block中將此布爾值設置為YES。
-
這里我們還要注意:
- 這是一種方便的方法。 它相當于創建一個
NSLinguisticTagger
的實例,將接收者指定為要分析的字符串,并使用正字法(或nil),然后調用NSLinguisticTagger
方法或枚舉TagsInRange:scheme:options:usingBlock:
。
結論:我表示我沒用過,一次都沒有。
二、- (NSArray<NSString *> *)linguisticTagsInRange:(NSRange)range scheme:(NSString *)tagScheme options:(NSLinguisticTaggerOptions)opts orthography:(NSOrthography *)orthography tokenRanges:(NSArray<NSValue *> * _Nullable *)tokenRanges;
該方法的作用就是:返回接收字符串中指定范圍和請求的標簽的語言標簽數組。
下面我們看一下參數和返回值:
-
range
:要分析字符串的區間。 -
tagScheme
:要使用的標簽方案。 請參閱支持值的語言標簽方案。 -
opts
:使用的語言標簽選項。 請參閱NSLinguisticTaggerOptions
的常量。 這些常數可以使用C位按OR運算符進行組合。這個枚舉值前面已經給出了,這里就不多說了。 -
orthography
:字符串的正字法。 如果沒有,語言標簽將嘗試從字符串內容中確定正字法。 -
tokenRanges
:由引用返回的數組,包含包含在NSValue對象中的語言標簽的令牌范圍。 -
return
:返回一個包含接收字符串中tokenRanges的語言標簽的數組。
下面我們還要注意:
- 這是一種方便的方法。 它相當于創建一個
NSLinguisticTagger
的實例,將接收者指定為要分析的字符串,以及正字法(或nil),然后調用NSLinguisticTagger
方法或linguisticTagsInRange:scheme:options:orthography:tokenRanges:
。
結論:我表示我沒用過,一次都沒有。
后記
關于
NSString
類的知識就此完結了,希望大家能批評指正,能幫助到大家,喜歡的別忘記喜歡和關注哦!!!!