Как инициализировать строку из NSData в Swift

Я пытался инициализировать строку из NSData в Swift.

на Документация NSString Cocoa компания Apple говорит, что вы должны использовать это:

 init(data data: NSData!, encoding encoding: UInt)

однако Apple не включила какой-либо пример для использования или куда поместить init.

Я пытаюсь преобразовать следующий код из Objective-C в Swift

NSString *string;
string = [[NSString alloc] initWithData: data encoding: NSUTF8StringEncoding];

Я пробовал много возможных синтаксисов, таких как следующие (конечно, это не работа):

var string:NSString!
string = init(data: fooData,encoding: NSUTF8StringEncoding)

7 ответов


вот как вы должны инициализировать NSString:

Swift 2.X или старше

let datastring = NSString(data: fooData, encoding: NSUTF8StringEncoding)

Swift 3 или новее:

let datastring = NSString(data: fooData, encoding: String.Encoding.utf8.rawValue)

этот документ объясняет синтаксис.


это реализовано код:

в Swift 3.0:

var dataString = String(data: fooData, encoding: String.Encoding.utf8)

или просто

var dataString = String(data: fooData, encoding: .utf8)

старая версия swift:

в Swift 2.0:

import Foundation

var dataString = String(data: fooData, encoding: NSUTF8StringEncoding)

в Swift 1.0:

var dataString = NSString(data: fooData, encoding:NSUTF8StringEncoding)

Swift 2.0

кажется, что Swift 2.0 фактически представил String(data:encoding:) как расширение строки при импорте Foundation. Как ни странно, я не нашел места, где это задокументировано.

(pre Swift 2.0) облегченное расширение

вот копия-pasteable мало расширений, не используя NSString, давайте отрежем посредника.

import Foundation

extension NSData
{
    var byteBuffer : UnsafeBufferPointer<UInt8> { get { return UnsafeBufferPointer<UInt8>(start: UnsafeMutablePointer<UInt8>(self.bytes), count: self.length) }}
}

extension String
{
    init?(data : NSData, encoding : NSStringEncoding)
    {
        self.init(bytes: data.byteBuffer, encoding: encoding)
    }
}

// Playground test
let original = "Nymphs blitz quick vex dwarf jog"
let encoding = NSASCIIStringEncoding

if let data = original.dataUsingEncoding(encoding)
{
    String(data: data, encoding: encoding)
}

это также дает вам доступ к data.byteBuffer тип последовательности, так что все те крутые операции, которые вы можете делать с последовательностями, также работают, например,reduce { &+ } для контрольной суммы.

Примечания

в моем предыдущем редактировании я использовал этот метод:

var buffer = Array<UInt8>(count: data.length, repeatedValue: 0x00)
data.getBytes(&buffer, length: data.length)
self.init(bytes: buffer, encoding: encoding)

проблема с этим подходом заключается в том, что я создаю копию информации в новый массив, таким образом, я дублирую количество байтов (в частности: encoding size * data.length)


начиная с третьей версии Swift вы можете сделать следующее:

let desiredString = NSString(data: yourData, encoding: String.Encoding.utf8.rawValue)

simialr к чему Sunkas посоветовал.


import Foundation
var string = NSString(data: NSData?, encoding: UInt)

другой ответ, основанный на расширениях (мальчик, я скучаю по этому в Java):

extension NSData {
    func toUtf8() -> String? {
        return String(data: self, encoding: NSUTF8StringEncoding)
    }
}

затем вы можете использовать:

let data : NSData = getDataFromEpicServer()
let string : String? = data.toUtf8() 

обратите внимание, что строка является необязательной, начальный NSData может быть не конвертируемым в Utf8.


С

NSData *myStringData = [@"My String" dataUsingEncoding:NSUTF8StringEncoding]; 
NSString *myStringFromData = [[NSString alloc] initWithData:myStringData encoding:NSUTF8StringEncoding];
NSLog(@"My string value: %@",myStringFromData);

Свифт

//This your data containing the string
   let myStringData = "My String".dataUsingEncoding(NSUTF8StringEncoding)

   //Use this method to convert the data into String
   let myStringFromData =  String(data:myStringData!, encoding: NSUTF8StringEncoding)

   print("My string value:" + myStringFromData!)

http://objectivec2swift.blogspot.in/2016/03/coverting-nsdata-to-nsstring-or-convert.html