คุณสามารถใช้ ML Kit เพื่อระบุภาษาของสตริงข้อความได้ คุณสามารถรับภาษาที่มีแนวโน้มมากที่สุดของสตริงหรือรับคะแนนความเชื่อมั่นสำหรับภาษาที่เป็นไปได้ทั้งหมดของสตริง
ML Kit จดจำข้อความใน 103 ภาษาที่แตกต่างกันด้วยสคริปต์ดั้งเดิม นอกจากนี้ ข้อความแบบโรมันยังสามารถจดจำได้สำหรับอารบิก บัลแกเรีย จีน กรีก ฮินดี ญี่ปุ่น และรัสเซีย
ก่อนที่คุณจะเริ่ม
- หากคุณยังไม่ได้เพิ่ม Firebase ลงในแอปของคุณ ให้ทำตามขั้นตอนใน คู่มือการเริ่มต้นใช้งาน
- รวมไลบรารี ML Kit ไว้ใน Podfile ของคุณ:
pod 'Firebase/MLNaturalLanguage', '6.25.0' pod 'Firebase/MLNLLanguageID', '6.25.0'
หลังจากที่คุณติดตั้งหรืออัปเดต Pod ของโปรเจ็กต์แล้ว อย่าลืมเปิดโปรเจ็กต์ Xcode โดยใช้.xcworkspace
- ในแอปของคุณ ให้นำเข้า Firebase:
สวิฟท์
import Firebase
วัตถุประสงค์-C
@import Firebase;
ระบุภาษาของสตริง
หากต้องการระบุภาษาของสตริง ให้รับอินสแตนซ์ของ LanguageIdentification
จากนั้นส่งสตริงไปยัง identifyLanguage(for:)
ตัวอย่างเช่น:
สวิฟท์
let languageId = NaturalLanguage.naturalLanguage().languageIdentification()
languageId.identifyLanguage(for: text) { (languageCode, error) in
if let error = error {
print("Failed with error: \(error)")
return
}
if let languageCode = languageCode, languageCode != "und" {
print("Identified Language: \(languageCode)")
} else {
print("No language was identified")
}
}
วัตถุประสงค์-C
FIRNaturalLanguage *naturalLanguage = [FIRNaturalLanguage naturalLanguage];
FIRLanguageIdentification *languageId = [naturalLanguage languageIdentification];
[languageId identifyLanguageForText:text
completion:^(NSString * _Nullable languageCode,
NSError * _Nullable error) {
if (error != nil) {
NSLog(@"Failed with error: %@", error.localizedDescription);
return;
}
if (languageCode != nil
&& ![languageCode isEqualToString:@"und"] ) {
NSLog(@"Identified Language: %@", languageCode);
} else {
NSLog(@"No language was identified");
}
}];
หากการโทรสำเร็จ รหัสภาษา BCP-47 จะถูกส่งไปยังตัวจัดการการเสร็จสิ้น ซึ่งระบุภาษาของข้อความ ดู รายการภาษาที่รองรับทั้งหมด หากตรวจไม่พบภาษาได้อย่างมั่นใจ รหัส und
(ไม่ได้ระบุ) จะถูกส่งผ่าน
ตามค่าเริ่มต้น ML Kit จะส่งกลับค่าที่ไม่ใช่ und
เฉพาะเมื่อระบุภาษาที่มีค่าความเชื่อมั่นอย่างน้อย 0.5 คุณสามารถเปลี่ยนเกณฑ์นี้ได้โดยส่งวัตถุ LanguageIdentificationOptions
ไปที่ languageIdentification(options:)
:
สวิฟท์
let options = LanguageIdentificationOptions(confidenceThreshold: 0.4)
let languageId = NaturalLanguage.naturalLanguage().languageIdentification(options: options)
วัตถุประสงค์-C
FIRNaturalLanguage *naturalLanguage = [FIRNaturalLanguage naturalLanguage];
FIRLanguageIdentificationOptions *options =
[[FIRLanguageIdentificationOptions alloc] initWithConfidenceThreshold:0.4];
FIRLanguageIdentification *languageId =
[naturalLanguage languageIdentificationWithOptions:options];
รับภาษาที่เป็นไปได้ของสตริง
หากต้องการรับค่าความเชื่อมั่นของภาษาที่มีแนวโน้มมากที่สุดของสตริง ให้รับอินสแตนซ์ของ LanguageIdentification
จากนั้นส่งสตริงไปยัง identifyPossibleLanguages(for:)
ตัวอย่างเช่น:
สวิฟท์
let languageId = NaturalLanguage.naturalLanguage().languageIdentification()
languageId.identifyPossibleLanguages(for: text) { (identifiedLanguages, error) in
if let error = error {
print("Failed with error: \(error)")
return
}
guard let identifiedLanguages = identifiedLanguages,
!identifiedLanguages.isEmpty,
identifiedLanguages[0].languageCode != "und"
else {
print("No language was identified")
return
}
print("Identified Languages:\n" +
identifiedLanguages.map {
String(format: "(%@, %.2f)", $0.languageCode, $0.confidence)
}.joined(separator: "\n"))
}
วัตถุประสงค์-C
FIRNaturalLanguage *naturalLanguage = [FIRNaturalLanguage naturalLanguage];
FIRLanguageIdentification *languageId = [naturalLanguage languageIdentification];
[languageId identifyPossibleLanguagesForText:text
completion:^(NSArray<FIRIdentifiedLanguage *> * _Nonnull identifiedLanguages,
NSError * _Nullable error) {
if (error != nil) {
NSLog(@"Failed with error: %@", error.localizedDescription);
return;
}
if (identifiedLanguages.count == 1
&& [identifiedLanguages[0].languageCode isEqualToString:@"und"] ) {
NSLog(@"No language was identified");
return;
}
NSMutableString *outputText = [NSMutableString stringWithFormat:@"Identified Languages:"];
for (FIRIdentifiedLanguage *language in identifiedLanguages) {
[outputText appendFormat:@"\n(%@, %.2f)", language.languageCode, language.confidence];
}
NSLog(outputText);
}];
ถ้าการโทรสำเร็จ รายการของวัตถุ IdentifiedLanguage
จะถูกส่งผ่านไปยังตัวจัดการความต่อเนื่อง จากแต่ละอ็อบเจ็กต์ คุณสามารถรับโค้ด BCP-47 ของภาษาและความมั่นใจว่าสตริงนั้นเป็นภาษานั้นได้ ดู รายการภาษาที่รองรับทั้งหมด โปรดทราบว่าค่าเหล่านี้บ่งบอกถึงความมั่นใจว่าสตริงทั้งหมดเป็นภาษาที่กำหนด ML Kit ไม่ได้ระบุหลายภาษาในสตริงเดียว
ตามค่าเริ่มต้น ML Kit จะส่งคืนเฉพาะภาษาที่มีค่าความเชื่อมั่นอย่างน้อย 0.01 คุณสามารถเปลี่ยนเกณฑ์นี้ได้โดยส่งวัตถุ LanguageIdentificationOptions
ไปที่ languageIdentification(options:)
:
สวิฟท์
let options = LanguageIdentificationOptions(confidenceThreshold: 0.4)
let languageId = NaturalLanguage.naturalLanguage().languageIdentification(options: options)
วัตถุประสงค์-C
FIRNaturalLanguage *naturalLanguage = [FIRNaturalLanguage naturalLanguage];
FIRLanguageIdentificationOptions *options =
[[FIRLanguageIdentificationOptions alloc] initWithConfidenceThreshold:0.4];
FIRLanguageIdentification *languageId =
[naturalLanguage languageIdentificationWithOptions:options];
หากไม่มีภาษาที่ตรงตามเกณฑ์นี้ รายการจะมีหนึ่งรายการ โดยมีค่า und