テキストファイルから文字列を読み書きする


298

テキストファイルとの間でデータを読み書きする必要がありますが、その方法がわかりません。

このサンプルコードをSwiftのiBookで見つけましたが、データの書き込みまたは読み取り方法がまだわかりません。

import Cocoa

class DataImporter
{
    /*
    DataImporter is a class to import data from an external file.
    The class is assumed to take a non-trivial amount of time to initialize.
    */
    var fileName = "data.txt"
    // the DataImporter class would provide data importing functionality here
}

class DataManager
{
    @lazy var importer = DataImporter()
    var data = String[]()
    // the DataManager class would provide data management functionality here
}

let manager = DataManager()
manager.data += "Some data"
manager.data += "Some more data"
// the DataImporter instance for the importer property has not yet been created”

println(manager.importer.fileName)
// the DataImporter instance for the importer property has now been created
// prints "data.txt”



var str = "Hello World in Swift Language."

回答:


547

読み取りと書き込みには、ドキュメントディレクトリなど、書き込み可能な場所を使用する必要があります。次のコードは、単純な文字列を読み書きする方法を示しています。遊び場でテストできます。

Swift 3.x-5.x

let file = "file.txt" //this is the file. we will write to and read from it

let text = "some text" //just a text

if let dir = FileManager.default.urls(for: .documentDirectory, in: .userDomainMask).first {

    let fileURL = dir.appendingPathComponent(file)

    //writing
    do {
        try text.write(to: fileURL, atomically: false, encoding: .utf8)
    }
    catch {/* error handling here */}

    //reading
    do {
        let text2 = try String(contentsOf: fileURL, encoding: .utf8)
    }
    catch {/* error handling here */}
}

Swift 2.2

let file = "file.txt" //this is the file. we will write to and read from it

let text = "some text" //just a text

if let dir = NSSearchPathForDirectoriesInDomains(NSSearchPathDirectory.DocumentDirectory, NSSearchPathDomainMask.AllDomainsMask, true).first {
    let path = NSURL(fileURLWithPath: dir).URLByAppendingPathComponent(file)

    //writing
    do {
        try text.writeToURL(path, atomically: false, encoding: NSUTF8StringEncoding)
    }
    catch {/* error handling here */}

    //reading
    do {
        let text2 = try NSString(contentsOfURL: path, encoding: NSUTF8StringEncoding)
    }
    catch {/* error handling here */}
}

Swift 1.x

let file = "file.txt"

if let dirs : [String] = NSSearchPathForDirectoriesInDomains(NSSearchPathDirectory.DocumentDirectory, NSSearchPathDomainMask.AllDomainsMask, true) as? [String] {
    let dir = dirs[0] //documents directory
    let path = dir.stringByAppendingPathComponent(file);
    let text = "some text"

    //writing
    text.writeToFile(path, atomically: false, encoding: NSUTF8StringEncoding, error: nil);

    //reading
    let text2 = String(contentsOfFile: path, encoding: NSUTF8StringEncoding, error: nil)
}

2
let text2 = String.stringWithContentsOfFile(path)// XCode 6.0
Matt Frear

このソリューションを使用しても機能しますが、ファイルを開いてもテキストはありません。何か不足していますか?
NunoGonçalves2014年

@Adam let path = dir.stringByAppendingPathComponent(file);にあるこのファイルは何ですか?
zbz.lvlv 2014

7
これは削除する必要があります。コードは新しいバージョンのSwiftでは機能しません。

1
@ billy_b29この行の後のコード://readingまさにそれを行います。
アダム

88

テキストファイルdata.txtをXcodeプロジェクトに移動したと仮定すると(ドラッグアンドドロップを使用し、[必要に応じてファイルをコピーする]をオンにします)、Objective-Cと同様に次の操作を実行できます。

let bundle = NSBundle.mainBundle()
let path = bundle.pathForResource("data", ofType: "txt")        
let content = NSString.stringWithContentsOfFile(path) as String

println(content) // prints the content of data.txt

更新:
Bundle(iOS)からファイルを読み取るには、以下を使用できます。

let path = NSBundle.mainBundle().pathForResource("FileName", ofType: "txt")
var text = String(contentsOfFile: path!, encoding: NSUTF8StringEncoding, error: nil)!
println(text)

Swift 3の更新:

let path = Bundle.main.path(forResource: "data", ofType: "txt") // file path for file "data.txt"
var text = String(contentsOfFile: path!, encoding: NSUTF8StringEncoding, error: nil)!

Swift 5の場合

let path = Bundle.main.path(forResource: "ListAlertJson", ofType: "txt") // file path for file "data.txt"
let string = try String(contentsOfFile: path!, encoding: String.Encoding.utf8)

3
iOSプロジェクトの場合、 "stringWithContentsOfFile"は使用できません(iOS 7で非推奨)
alttag '23 / 10/23

1
iOSプロジェクトとは何の関係もありません
。Xcode6.1

1
String(contentsOfFile:...)を使用できます
shim

1
iOS 10 Swift 3の同様のソリューション使用バンドルはこちら
Timeless

69

Xcode 8.x•Swift 3.x以降

do {
    // get the documents folder url
    if let documentDirectory = FileManager.default.urls(for: .documentDirectory, in: .userDomainMask).first {
        // create the destination url for the text file to be saved
        let fileURL = documentDirectory.appendingPathComponent("file.txt")
        // define the string/text to be saved
        let text = "Hello World !!!"
        // writing to disk 
        // Note: if you set atomically to true it will overwrite the file if it exists without a warning
        try text.write(to: fileURL, atomically: false, encoding: .utf8)
        print("saving was successful")
        // any posterior code goes here
        // reading from disk
        let savedText = try String(contentsOf: fileURL)
        print("savedText:", savedText)   // "Hello World !!!\n"
    }
} catch {
    print("error:", error)
}

「そのようなファイルはありません」の最も一般的な間違いは何ですか。.txtファイルをプロジェクトナビゲーターに追加してからそれらを開こうとすると、このメッセージが表示されます。(デスクトップで作成し、プロジェクトナビゲーターにドラッグしました)
Darvydas 2015年

56

よりシンプルで推奨される新しい方法: Appleはファイル処理にURLを使用することを推奨しており、ここでの他のソリューションは推奨されないようです(以下のコメントを参照)。以下は、URLを使用した新しい読み書きの簡単な方法です(考えられるURLエラーを処理することを忘れないでください):

Swift 5 +、4、3.1

import Foundation  // Needed for those pasting into Playground

let fileName = "Test"
let dir = try? FileManager.default.url(for: .documentDirectory, 
      in: .userDomainMask, appropriateFor: nil, create: true)

// If the directory was found, we write a file to it and read it back
if let fileURL = dir?.appendingPathComponent(fileName).appendingPathExtension("txt") {

    // Write to the file named Test
    let outString = "Write this text to the file"
    do {
        try outString.write(to: fileURL, atomically: true, encoding: .utf8)
    } catch {
        print("Failed writing to URL: \(fileURL), Error: " + error.localizedDescription)
    }

    // Then reading it back from the file
    var inString = ""
    do {
        inString = try String(contentsOf: fileURL)
    } catch {
        print("Failed reading from URL: \(fileURL), Error: " + error.localizedDescription)
    }
    print("Read from the file: \(inString)")
}

1
Appleがそのような方法を推奨する場合のリファレンスを提供できますか。または、これが推奨される方法である理由についてもう少し詳しく説明できますか?
Andrej

6
@Andrej "ローカルファイルを参照するには、URLオブジェクトが推奨されます。ファイルからデータを読み書きするほとんどのオブジェクトには、ファイル参照としてパス名ではなくNSURLオブジェクトを受け入れるメソッドがあります。" developer.apple.com/library/ios/documentation/Cocoa/Reference/…–
Sverrisson

1
エラーをNSErrorとしてキャストしたり、「catch let error」を使用したりする必要はありません。キャッチするだけで、エラー変数を無料で取得できます。
cuomo456 2016年

@ cuomo456あなたの右私はそれを削除します、それは以前のSwiftベータからの残り物です。
Sverrisson

1
@Alshcompiler create:trueは、失敗する代わりに、FileManagerにディレクトリがまだない場合は作成するよう通知します
Sverrisson

28

Xcode 8、App Bundleからファイルを読み取るSwift 3の方法:

if let path = Bundle.main.path(forResource: filename, ofType: nil) {
    do {
        let text = try String(contentsOfFile: path, encoding: String.Encoding.utf8)
        print(text)
    } catch {
        printError("Failed to read text from \(filename)")
    }
} else {
    printError("Failed to load file from app bundle \(filename)")
} 

これは便利なコピーと貼り付けの拡張機能です

public extension String {
    func contentsOrBlank()->String {
        if let path = Bundle.main.path(forResource:self , ofType: nil) {
            do {
                let text = try String(contentsOfFile:path, encoding: String.Encoding.utf8)
                return text
                } catch { print("Failed to read text from bundle file \(self)") }
        } else { print("Failed to load file from bundle \(self)") }
        return ""
    }
    }

例えば

let t = "yourFile.txt".contentsOrBlank()

ほとんどの場合、行の配列が必要です。

let r:[String] = "yourFile.txt"
     .contentsOrBlank()
     .characters
     .split(separator: "\n", omittingEmptySubsequences:ignore)
     .map(String.init)

2
私は便利な拡張機能@crashalotに貼り付けました-削除してください、乾杯
Fattie

1
@Alshcompiler NO!バンドルにファイルを書き込むことはできません。
スヴェリソン

私はファイルからの読み取りについて話していました、それがファイルがプロジェクトファイルにある場合に私と一緒に機能した唯一の答えです
Alshコンパイラ

10

私はあなたに最初の部分、つまり読まれた部分だけを見せたいです。簡単に読む方法は次のとおりです。

スウィフト3:

let s = try String(contentsOfFile: Bundle.main.path(forResource: "myFile", ofType: "txt")!)

スウィフト2:

let s = try! String(contentsOfFile: NSBundle.mainBundle().pathForResource("myFile", ofType: "txt")!)

5

Swift> 4.0でファイルを読み取る最も簡単な方法

 let path = Bundle.main.path(forResource: "data", ofType: "txt") // file path for file "data.txt"
        do {
            var text = try String(contentsOfFile: path!)
        }
        catch(_){print("error")}
    }

3

上記のAdamからの現在の受け入れられた回答にはいくつかのエラーがありましたが、ここで私が彼の回答を書き直して、この作業を私のために行った方法を示します。

let file = "file.txt"

let dirs: [String]? = NSSearchPathForDirectoriesInDomains(NSSearchPathDirectory.DocumentDirectory, NSSearchPathDomainMask.AllDomainsMask, true) as? [String]

if (dirs != nil) {
    let directories:[String] = dirs!
    let dirs = directories[0]; //documents directory
    let path = dirs.stringByAppendingPathComponent(file);
    let text = "some text"

    //writing
    text.writeToFile(path, atomically: false, encoding: NSUTF8StringEncoding, error: nil);

    //reading
     var error:NSError?

    //reading
    let text2 = String(contentsOfFile: path, encoding:NSUTF8StringEncoding, error: &error)

    if let theError = error {
        print("\(theError.localizedDescription)")
    }
}

3

このツールは、Swiftのファイルから読み取るだけでなく、入力の解析にも役立ちます。https//github.com/shoumikhin/StreamScanner

次のようにファイルパスとデータ区切り文字を指定するだけです。

import StreamScanner

if let input = NSFileHandle(forReadingAtPath: "/file/path")
{
    let scanner = StreamScanner(source: input, delimiters: NSCharacterSet(charactersInString: ":\n"))  //separate data by colons and newlines

    while let field: String = scanner.read()
    {
        //use field
    }
}

お役に立てれば。


2

私はこのように再コーディングする必要がありました:

let path = NSBundle.mainBundle().pathForResource("Output_5", ofType: "xml")
let text = try? NSString(contentsOfFile: path! as String, encoding: NSUTF8StringEncoding)
print(text)

2

関数の例では、いくつかの関数ラッパーを持つ(read | write)DocumentsFromFile(...)は確かに理にかなっているように見えます。 182か国で、ファイルに "Hi"を書き込むためだけにインスタンス化および設定されています。

ただし、これらの例は実際のプログラムで使用するには十分ではありません。書き込み関数は、ファイルの作成またはファイルへの書き込みエラーを報告しません。読み取り時に、読み取られたデータを含むはずの文字列としてファイルが存在しないというエラーを返すのは良い考えではないと思います。あなたはそれが失敗したことと、なぜ例外のような何らかの通知メカニズムを通じてその理由を知りたいでしょう。次に、何が問題であるかを出力し、ユーザーがそれを修正できるようにする、またはその時点でプログラムを「正しく」中断するコードを記述できます。

「エラーファイルが存在しない」という文字列だけを返す必要はありません。次に、関数を呼び出すたびに文字列のエラーを探し、そこで処理する必要があります。また、エラー文字列が実際に実際のファイルから読み取られたものなのか、それともコードから生成されたものなのか、実際にはわかりません。

NSString(contentsOfFile ...)が例外をスローするため、Swift 2.2およびXcode 7.3では、このような読み取りを呼び出すこともできません。それをキャッチしてstdoutへの出力やエラーポップアップウィンドウ、stderrなどの何かを行うコードがない場合は、コンパイル時エラーです。Appleはトライキャッチと例外から遠ざかっていると聞いていますが、これは長い道のりであり、これなしにコードを書くことは不可能です。&error引数がどこから来たのかわかりませんが、おそらく古いバージョンですが、NSString.writeTo [File | URL]には現在NSError引数がありません。これらはNSString.hで次のように定義されています。

public func writeToURL(url: NSURL, atomically useAuxiliaryFile: Bool, encoding enc: UInt) throws
public func writeToFile(path: String, atomically useAuxiliaryFile: Bool, encoding enc: UInt) throws
public convenience init(contentsOfURL url: NSURL, encoding enc: UInt) throws
public convenience init(contentsOfFile path: String, encoding enc: UInt) throws

また、存在しないファイルは、アクセス許可の問題、ファイルサイズ、またはハンドラーのコーディングを試みたくない他の多くの問題など、プログラムがファイルを読み取るときに発生する可能性のある多くの潜在的な問題の1つにすぎませんそれらのそれぞれ。それがすべて正しいと仮定して、何かがうまくいかなかった場合の例外をキャッチして出力するか、処理することをお勧めします。さらに、この時点では、とにかく本当に選択肢がありません。

これが私の書き直しです:

func writeToDocumentsFile(fileName:String,value:String) {

    let documentsPath = NSSearchPathForDirectoriesInDomains(.DocumentDirectory, .UserDomainMask, true)[0] as NSString!
    let path = documentsPath.stringByAppendingPathComponent(fileName)

    do {
        try value.writeToFile(path, atomically: true, encoding: NSUTF8StringEncoding)
    } catch let error as NSError {
        print("ERROR : writing to file \(path) : \(error.localizedDescription)")
    }

}

func readFromDocumentsFile(fileName:String) -> String {

    let documentsPath = NSSearchPathForDirectoriesInDomains(.DocumentDirectory, .UserDomainMask, true)[0] as NSString
    let path = documentsPath.stringByAppendingPathComponent(fileName)

    var readText : String = ""

    do {
        try readText = NSString(contentsOfFile: path, encoding: NSUTF8StringEncoding) as String
    }
    catch let error as NSError {
        print("ERROR : reading from file \(fileName) : \(error.localizedDescription)")
    }
    return readText
}

あなたの多くの回答では、あなたは私のポイントを理解していないと思います。(またはあなたは気にしないかもしれません、そしてそれは大丈夫です)。ただし、明確にするには、例外をスローし、そこにないファイルを探しているときに(または、権限などの別の問題があるときに)何らかの方法で処理する方が、「ERROR:File [filename]」のような文字列を返すよりもはるかに優れています。存在しない」という文字列が実際にファイルから読み取られるはずだったためです。次に、それを印刷します。何かが必要な場合は、例外の詳細を出力する必要がありますが、エラーが発生した読み取りに失敗した文字列ではありません。プログラムはおそらく続行するだけではいけません。
Sam Allen

2

私のtxtファイルはこのように機能します:

let myFileURL = NSBundle.mainBundle().URLForResource("listacomuni", withExtension: "txt")!
let myText = try! String(contentsOfURL: myFileURL, encoding: NSISOLatin1StringEncoding)
print(String(myText))

2

混乱を避けて簡単にするために、ドキュメントディレクトリ内のファイルに対して文字列の読み取りと書き込みを行う2つの関数を作成しました。ここに関数があります:

func writeToDocumentsFile(fileName:String,value:String) {
    let documentsPath = NSSearchPathForDirectoriesInDomains(.DocumentDirectory, .UserDomainMask, true)[0] as! NSString
    let path = documentsPath.stringByAppendingPathComponent(fileName)
    var error:NSError?
    value.writeToFile(path, atomically: true, encoding: NSUTF8StringEncoding, error: &error)
}

func readFromDocumentsFile(fileName:String) -> String {
    let documentsPath = NSSearchPathForDirectoriesInDomains(.DocumentDirectory, .UserDomainMask, true)[0] as! NSString
    let path = documentsPath.stringByAppendingPathComponent(fileName)
    var checkValidation = NSFileManager.defaultManager()
    var error:NSError?
    var file:String

    if checkValidation.fileExistsAtPath(path) {
        file = NSString(contentsOfFile: path, encoding: NSUTF8StringEncoding, error: nil) as! String
    } else {
        file = "*ERROR* \(fileName) does not exist."
    }

    return file
}

以下はその使用例です。

writeToDocumentsFile("MyText.txt","Hello world!")

let value = readFromDocumentsFile("MyText.txt")
println(value)  //Would output 'Hello world!'

let otherValue = readFromDocumentsFile("SomeText.txt")
println(otherValue)  //Would output '*ERROR* SomeText.txt does not exist.'

お役に立てれば!

Xcodeバージョン:6.3.2


2

最新のswift3コード次のコードを
使用するだけで、テキストファイルからデータを読み取ることができます。このテキストファイル

     {
"NumberOfSlices": "8",
"NrScenes": "5",
"Scenes": [{
           "dataType": "label1",
           "image":"http://is3.mzstatic.com/image/thumb/Purple19/v4/6e/81/31/6e8131cf-2092-3cd3-534c-28e129897ca9/mzl.syvaewyp.png/53x53bb-85.png",

           "value": "Hello",
           "color": "(UIColor.red)"
           }, {
           "dataType": "label2",
           "image":"http://is1.mzstatic.com/image/thumb/Purple71/v4/6c/4c/c1/6c4cc1bc-8f94-7b13-f3aa-84c41443caf3/mzl.hcqvmrix.png/53x53bb-85.png",
           "value": "Hi There",
           "color": "(UIColor.blue)"
           }, {
           "dataType": "label3",
           "image":"http://is1.mzstatic.com/image/thumb/Purple71/v4/6c/4c/c1/6c4cc1bc-8f94-7b13-f3aa-84c41443caf3/mzl.hcqvmrix.png/53x53bb-85.png",

           "value": "hi how r u ",
           "color": "(UIColor.green)"
           }, {
           "dataType": "label4",
           "image":"http://is1.mzstatic.com/image/thumb/Purple71/v4/6c/4c/c1/6c4cc1bc-8f94-7b13-f3aa-84c41443caf3/mzl.hcqvmrix.png/53x53bb-85.png",
           "value": "what are u doing  ",
           "color": "(UIColor.purple)"
           }, {
           "dataType": "label5",
          "image":"http://is1.mzstatic.com/image/thumb/Purple71/v4/6c/4c/c1/6c4cc1bc-8f94-7b13-f3aa-84c41443caf3/mzl.hcqvmrix.png/53x53bb-85.png",
           "value": "how many times ",
           "color": "(UIColor.white)"
           }, {
           "dataType": "label6",
           "image":"http://is1.mzstatic.com/image/thumb/Purple71/v4/5a/f3/06/5af306b0-7cac-1808-f440-bab7a0d18ec0/mzl.towjvmpm.png/53x53bb-85.png",
           "value": "hi how r u ",
           "color": "(UIColor.blue)"
           }, {
           "dataType": "label7",
           "image":"http://is5.mzstatic.com/image/thumb/Purple71/v4/a8/dc/eb/a8dceb29-6daf-ca0f-d037-df9f34cdc476/mzl.ukhhsxik.png/53x53bb-85.png",
           "value": "hi how r u ",
           "color": "(UIColor.gry)"
           }, {
           "dataType": "label8",
           "image":"http://is2.mzstatic.com/image/thumb/Purple71/v4/15/23/e0/1523e03c-fff2-291e-80a7-73f35d45c7e5/mzl.zejcvahm.png/53x53bb-85.png",
           "value": "hi how r u ",
           "color": "(UIColor.brown)"
           }]

}

このコードを使用して、swift3のテキストJSONファイルからデータを取得できます

     let filePath = Bundle.main.path(forResource: "nameoftheyourjsonTextfile", ofType: "json")


    let contentData = FileManager.default.contents(atPath: filePath!)
    let content = NSString(data: contentData!, encoding: String.Encoding.utf8.rawValue) as? String

    print(content)
    let json = try! JSONSerialization.jsonObject(with: contentData!) as! NSDictionary
    print(json)
    let app = json.object(forKey: "Scenes") as! NSArray!
    let _ : NSDictionary
    for dict in app! {
        let colorNam = (dict as AnyObject).object(forKey: "color") as! String
        print("colors are \(colorNam)")

       // let colour = UIColor(hexString: colorNam) {
       // colorsArray.append(colour.cgColor)
       // colorsArray.append(colorNam  as! UIColor)

        let value = (dict as AnyObject).object(forKey: "value") as! String
        print("the values are \(value)")
        valuesArray.append(value)

        let images = (dict as AnyObject).object(forKey: "image") as! String
        let url = URL(string: images as String)
        let data = try? Data(contentsOf: url!)
        print(data)
        let image1 = UIImage(data: data!)! as UIImage
        imagesArray.append(image1)
         print(image1)
            }


1

ViewDidLoadに書き込む

var error: NSError?
var paths = NSSearchPathForDirectoriesInDomains(.DocumentDirectory, NSSearchPathDomainMask.UserDomainMask, true)
var documentsDirectory = paths.first as String
var dataPath = documentsDirectory.stringByAppendingPathComponent("MyFolder")

if !NSFileManager.defaultManager().fileExistsAtPath(dataPath) {
    NSFileManager.defaultManager().createDirectoryAtPath(dataPath, withIntermediateDirectories: false, attributes: nil, error: &error)
} else {
    println("not creted or exist")
}

func listDocumentDirectoryfiles() -> [String] {
    if let documentDirectory = NSSearchPathForDirectoriesInDomains(.DocumentDirectory, .UserDomainMask, true).first as? String {
        let myFilePath = documentDirectory.stringByAppendingPathComponent("MyFolder")
        return NSFileManager.defaultManager().contentsOfDirectoryAtPath(myFilePath, error: nil) as [String]
    }
    return []
}

1

以前の解決策は質問に答えますが、私の場合、書き込み中にファイルの古いコンテンツを削除することが問題でした。

そこで、以前のコンテンツを削除せずにドキュメントディレクトリのファイルに書き込むためのコードを作成しました。おそらく、より優れたエラー処理が必要ですが、それは良い出発点だと思います。Swift 4. Usuage:

    let filename = "test.txt"
    createOrOverwriteEmptyFileInDocuments(filename: filename)
    if let handle = getHandleForFileInDocuments(filename: filename) {
        writeString(string: "aaa", fileHandle: handle)
        writeString(string: "bbb", fileHandle: handle)
        writeString(string: "\n", fileHandle: handle)
        writeString(string: "ccc", fileHandle: handle)
    }

ヘルパーメソッド:

func createOrOverwriteEmptyFileInDocuments(filename: String){
    guard let dir = FileManager.default.urls(for: .documentDirectory, in: .userDomainMask).first else {
        debugPrint("ERROR IN createOrOverwriteEmptyFileInDocuments")
        return
    }
    let fileURL = dir.appendingPathComponent(filename)
    do {
        try "".write(to: fileURL, atomically: true, encoding: .utf8)
    }
    catch {
        debugPrint("ERROR WRITING STRING: " + error.localizedDescription)
    }
    debugPrint("FILE CREATED: " + fileURL.absoluteString)
}

private func writeString(string: String, fileHandle: FileHandle){
    let data = string.data(using: String.Encoding.utf8)
    guard let dataU = data else {
        debugPrint("ERROR WRITING STRING: " + string)
        return
    }
    fileHandle.seekToEndOfFile()
    fileHandle.write(dataU)
}

private func getHandleForFileInDocuments(filename: String)->FileHandle?{
    guard let dir = FileManager.default.urls(for: .documentDirectory, in: .userDomainMask).first else {
        debugPrint("ERROR OPENING FILE")
        return nil
    }
    let fileURL = dir.appendingPathComponent(filename)
    do {
        let fileHandle: FileHandle? = try FileHandle(forWritingTo: fileURL)
        return fileHandle
    }
    catch {
        debugPrint("ERROR OPENING FILE: " + error.localizedDescription)
        return nil
    }
}

1

Swift 3.x-5.x

最良の例は、ローカルLogfile.txt 表示および表示できる拡張子を持つローカルを作成することです"Files App"、現在の日付と時刻をファイル名として

このコードをinfo.plistに追加するだけで、これら2つの機能が有効になります

  UIFileSharingEnabled
  LSSupportsOpeningDocumentsInPlace

以下のこの関数

var logfileName : String = ""
func getTodayString() -> String{

    let date = Date()
    let calender = Calendar.current
    let components = calender.dateComponents([.year,.month,.day,.hour,.minute,.second], from: date)

    let year = components.year
    let month = components.month
    let day = components.day
    let hour = components.hour
    let minute = components.minute
    let second = components.second

    let today_string = String(year!) + "-" + String(month!) + "-" + String(day!) + "-" + String(hour!)  + "" + String(minute!) + "" +  String(second!)+".txt"

    return today_string

}

func LogCreator(){
    logfileName = getTodayString()

    print("LogCreator: Logfile Generated Named: \(logfileName)")

    let file = logfileName //this is the file. we will write to and read from it

    let text = "some text" //just a text

    if let dir = FileManager.default.urls(for: .documentDirectory, in: .userDomainMask).first {

        let fileURL = dir.appendingPathComponent(file)
        let documentPath = NSSearchPathForDirectoriesInDomains(.documentDirectory,.userDomainMask, true)[0]
        print("LogCreator: The Logs are Stored at location \(documentPath)")


        //writing
        do {
            try text.write(to: fileURL, atomically: false, encoding: .utf8)
        }
        catch {/* error handling here */}

        //reading
        do {
            let text2 = try String(contentsOf: fileURL, encoding: .utf8)
            print("LogCreator: The Detail log are :-\(text2)")
        }
        catch {/* error handling here */}
    }
}


  [1]: https://i.stack.imgur.com/4eg12.png

私はこれを試しましたが、何かを見逃していたに違いありません。それは私のドキュメントを保存し、それをfile:/// var / mobile / Containers / Data / Application / E4BF1065-3B48-4E53-AC1D-0DC893CCB498 / Documents /に置きますが、ファイルで見つけることができません。
user3069232

1
このキーを見逃しました... <key> CFBundleDisplayName </ key> <string> $ {PRODUCT_NAME} </ string>はiOS 13、Swift 5
user3069232

0
 func writeToDocumentsFile(fileName:String,value:String) {
    let documentsPath = NSSearchPathForDirectoriesInDomains(.documentDirectory, .userDomainMask, true)[0] as NSString
    let path = documentsPath.appendingPathComponent(fileName)
    do{
    try value.write(toFile: path, atomically: true, encoding: String.Encoding.utf8)
}catch{
    }
    }

func readFromDocumentsFile(fileName:String) -> String {
    let documentsPath = NSSearchPathForDirectoriesInDomains(.documentDirectory, .userDomainMask, true)[0] as NSString
    let path = documentsPath.appendingPathComponent(fileName)
    let checkValidation = FileManager.default
    var file:String

    if checkValidation.fileExists(atPath: path) {
        do{
       try file = NSString(contentsOfFile: path, encoding: String.Encoding.utf8.rawValue) as String
        }catch{
            file = ""
        }
        } else {
        file = ""
    }

    return file
}

0

Xcodeの8.3.2スウィフト3.xの。NSKeyedArchiverおよびNSKeyedUnarchiverの使用

ドキュメントからファイルを読み取る

let documentsDirectoryPathString = NSSearchPathForDirectoriesInDomains(.documentDirectory, .userDomainMask, true).first!
let documentsDirectoryPath = NSURL(string: documentsDirectoryPathString)!
let jsonFilePath = documentsDirectoryPath.appendingPathComponent("Filename.json")

let fileManager = FileManager.default
var isDirectory: ObjCBool = false

if fileManager.fileExists(atPath: (jsonFilePath?.absoluteString)!, isDirectory: &isDirectory) {

let finalDataDict = NSKeyedUnarchiver.unarchiveObject(withFile: (jsonFilePath?.absoluteString)!) as! [String: Any]
}
else{
     print("File does not exists")
}

ドキュメントにファイルを書き込む

NSKeyedArchiver.archiveRootObject(finalDataDict, toFile:(jsonFilePath?.absoluteString)!)
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.