IOS开发:指定路径创建新文件夹

指定路径创建新文件夹

典型错误示范:

swift 复制代码
let documentDirectoryURL = FileManager.default.urls(for: .documentDirectory, in: .userDomainMask)[0]
let directoryURL = documentDirectoryURL.appendingPathComponent("FolderName", isDirectory: true)
        
        if FileManager.default.fileExists(atPath: directoryURL.path) {
             print(directoryURL.path)
        } else {
            do {
                try FileManager.default.createDirectory(at: directoryURL, withIntermediateDirectories: true, attributes: nil)
                print(directoryURL.path)
            } catch {
                print(error.localizedDescription)
            }
        }

很遗憾,网上所有相关的博文都是这样写的。但使用最新的swift5.8如此操作,会出现以下报错:

Cannot use instance member 'documentDirectoryURL' within property initializer; property initializers run before 'self' is available

以及:

Expression expected

出现第一个错误的原因是,在swift中的一个结构体在编译时,编译器无法识别属性在初始化后立刻用于另一个属性的初始化赋值。对编译器来说,一个结构体同一对大括号中的几个属性都是几乎同时初始化的,不一定完全按代码的书写顺序进行。要解决这个问题,需要用到结构体的初始化函数。

swift 复制代码
struct FileUtils {
    let fm: FileManager
    let documentDirectoryURL: URL
    let directoryURL: URL
    let dspURL: URL //  DSP folder's URL
    let eeURL: URL //  EEPROM folder's URL
    var dirIsExist: Bool
    
    init() {
        self.fm = FileManager.default
        self.documentDirectoryURL = fm.urls(for: .documentDirectory, in: .userDomainMask).first!
        self.directoryURL = documentDirectoryURL.appendingPathComponent("Bluetooth_Flash", conformingTo: .directory)
        self.dspURL = directoryURL.appendingPathComponent("DSP", conformingTo: .directory)
        self.eeURL = directoryURL.appendingPathComponent("EE", conformingTo: .directory)
        self.dirIsExist = fm.fileExists(atPath: directoryURL.path())
    }
}

出现第二个报错的原因是,在单独的结构体中不可以直接调用分支语句,应该设计一个专门的处理函数,把判断文件夹是否存在的条件分支语句放在一个函数里面。

swift 复制代码
struct FileUtils {
    let fm: FileManager
    let documentDirectoryURL: URL
    let directoryURL: URL
    let dspURL: URL //  DSP folder's URL
    let eeURL: URL //  EEPROM folder's URL
    var dirIsExist: Bool
    
    init() {
        self.fm = FileManager.default
        self.documentDirectoryURL = fm.urls(for: .documentDirectory, in: .userDomainMask).first!
        self.directoryURL = documentDirectoryURL.appendingPathComponent("Bluetooth_Flash", conformingTo: .directory)
        self.dspURL = directoryURL.appendingPathComponent("DSP", conformingTo: .directory)
        self.eeURL = directoryURL.appendingPathComponent("EE", conformingTo: .directory)
        self.dirIsExist = fm.fileExists(atPath: directoryURL.path())
    }
    
    func createdDirectoryIfNeeded() {
        if !dirIsExist {
            do {
                try fm.createDirectory(at: directoryURL, withIntermediateDirectories: true)
                print(directoryURL.path)
            } catch {
                print(error.localizedDescription)
            }
            
            do {
                try fm.createDirectory(at: dspURL, withIntermediateDirectories: true)
                print(dspURL.path)
            } catch {
                print(error.localizedDescription)
            }
            
            do {
                try fm.createDirectory(at: eeURL, withIntermediateDirectories: true)
                print(eeURL.path)
            } catch {
                print(error.localizedDescription)
            }
        }
    }
}

如果要在页面初始化的时候调用创建新文件夹的这个函数,我们需要先在这个页面的View结构体中实例化上面这个FileUtils结构体。然后我们需要初始化FileUtils的各个属性,再在View初始化函数中调用创建文件夹的函数。

swift 复制代码
struct FileView: View {
    //  Create the instance of FileUtils struct
    let fileUtils = FileUtils.init()
    
    //  Call createdDirectoryIfNeeded() function when FileView inited
    init() {
        fileUtils.createdDirectoryIfNeeded()
    }
}

最后记得在ContentView中根据自己的逻辑调用或初始化该页面。

相关推荐
2501_915106321 小时前
app 上架过程,安装包准备、证书与描述文件管理、安装测试、上传
android·ios·小程序·https·uni-app·iphone·webview
2501_915106322 小时前
使用 Sniffmaster TCP 抓包和 Wireshark 网络分析
网络协议·tcp/ip·ios·小程序·uni-app·wireshark·iphone
熊猫钓鱼>_>2 小时前
移动端开发技术选型报告:三足鼎立时代的开发者指南(2026年2月)
android·人工智能·ios·app·鸿蒙·cpu·移动端
徐同保1 天前
通过ip访问nginx的服务时,被第一个server重定向了,通过设置default_server解决这个问题
ios·iphone
2501_915918411 天前
在 iOS 环境下查看 App 详细信息与文件目录
android·ios·小程序·https·uni-app·iphone·webview
2501_916007471 天前
没有 Mac 用户如何上架 App Store,IPA生成、证书与描述文件管理、跨平台上传
android·macos·ios·小程序·uni-app·iphone·webview
夏幻灵2 天前
HTTPS全面解析:原理、加密机制与证书体
ios·iphone
TheNextByte12 天前
如何在iPhone上恢复已删除的笔记的综合指南
笔记·ios·iphone
rose and war2 天前
python和jinja版本问题导致的访问报500
python·ios
fendoudexiaoniao_ios2 天前
iOS 列表拖拽cell排序
ios·swift