1)现状:
我有一个文本文件(data.rtf)我也尝试过并且愿意使用.plist或任何其他格式来获得结果.
我一直在尝试从此文件中读取任何数据,并在Label上显示该数据.
我已经尝试预先填充文件,在读取之前保存到文件中,甚至只检查文件是否存在,但每次尝试都失败了.
在3天内,我搜索了各种指令和教程,了解如何做通常相当简单的功能.我已经使用Objective-C做了它,但我是Swift的新手,不幸的是我不得不用它进行评估而且我被卡住了.
2)障碍:
到目前为止,我所看到的每个例子都被XCode拒绝为错误的,因为使用了不再被接受的术语,如:
let path = (NstemporaryDirectory() as Nsstring).stringByAppendingPathComponent("image.png")
或者平坦的线条根本不起作用:
let client = arrayClients[0] displayLabel.text = "\(client.ob("FirstName")!) \(client.objectForKey("LastName")!)" //displayLabel.text = client. <- this part doesn't work
每个案例都以过时的代码结束工作,或者在将其更新为建议仍然有效的替换后过于屠杀.我获得代码甚至构建(删除语法错误)的唯一情况是逻辑错误,其中结果为空或者崩溃,最常见的是:
“NSCocoaErrorDomain Code = 260 “The file “data.rtf” Couldn’t be opened because there is no such file.”
“No such file or directory”
我认为,即使该文件存在于我的XCode项目中,它仍在iPhone模拟器中进行搜索,并且由于某种原因它在那里不存在.这只是一个理论,我不知道如何解决这个问题.我在使用Objective-C做同样的事情时从未遇到过这个问题,如果我创建了一个文件和路径,它可以工作,但对于Swift,它只是拒绝
3)守则:
在这一点上,我对一个有效的代码更感兴趣,而不是一个不能修复我的代码,因为我试图解决这个问题(以及其他XCode更新相关问题)已经变得如此拙劣,以至于它几乎不适合为了目的,即使我绕过这个障碍,但如果它有所帮助,我会提供“一些”我尝试的不同尝试
let path = (NstemporaryDirectory() as Nsstring).appendingPathComponent("data.rtf") do { // Get the contents let contents = try Nsstring(contentsOfFile: path,encoding: String.Encoding.utf8.rawValue) print(contents) displayLabel.text = contents as String? } catch let error as NSError { print("Ooops! let path = (Nstemp... did not work: \(error)") }
//具有相同结果的另一个变体:
let file: FileHandle? = FileHandle(forReadingAtPath: "DataFile.plist") if file != nil { // Read all the data let data = file?.readDataToEndOfFile() // Close the file file?.closeFile() // Convert our data to string let str = Nsstring(data: data!,encoding: String.Encoding.utf8.rawValue) print(str!) displayLabel.text = str as String? } else { print("Ooops! Something went wrong!") }
//一个版本,其中最后一行抛出(语法 – >编辑 – >致命)错误我无法解决:
var dictClients = [String:String]() var arrayClients = NSMutableArray() let path = Bundle.main.path(forResource: "data",ofType: "rtf") let filemgr = FileManager.default if filemgr.fileExists(atPath: path!) { do { let fullText = try String(contentsOfFile: path!,encoding: String.Encoding.utf8) let readings = fullText.components(separatedBy: "\n") as [String] for i in 1..<readings.count { let clientData = readings[i].components(separatedBy: "\t") dictClients["FirstName"] = "\(clientData)" arrayClients.add(dictClients) } } catch { print("error: \(error)") } } let client = arrayClients[0] //displayLabel.text = client. //displayLabel.text = "\(client.ob("FirstName")!) \(client.objectForKey("LastName")!)"
// -Edit – 我能够用下面的方法修复语法错误,但是却得到了一个逻辑错误
displayLabel.text = "\((client as AnyObject).object(forKey:"FirstName")!) \((client as AnyObject).object(forKey:"LastName")!)"
– 编辑新错误 –
“Fatal error: unexpectedly found nil while unwrapping an Optional value”
我希望这在某种程度上是清楚的,我感谢任何帮助解决问题.自星期四以来我一直在研究这个应用程序,这个特殊的问题从星期日开始,只有很少的睡眠或休息,甚至更多的计算机都在努力保持在紧张的情况下继续运行,我的重点不是那么强大,我可能不像我想,原谅我所犯的任何明显错误或我可能正在使用的沟通不畅.
提前致谢
解决方法
将RTF加载为Data,创建NSAttributedString并获取带有字符串属性的纯文本.
var arrayClients = [[String:String]]() // do not use NSMutableArray in Swift var dictClients = [String:String]() if let url = Bundle.main.url(forResource:"data",withExtension: "rtf") { do { let data = try Data(contentsOf:url) let attibutedString = try NSAttributedString(data: data,documentAttributes: nil) let fullText = attibutedString.string let readings = fullText.components(separatedBy: CharacterSet.newlines) for line in readings { // do not use ugly C-style loops in Swift let clientData = line.components(separatedBy: "\t") dictClients["FirstName"] = "\(clientData)" arrayClients.append(dictClients) } } catch { print(error) } }
但是对于那种数据结构,RTF并不合适.更好地使用JSON或属性列表.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。