【鴻蒙在 ETS (Extendable TypeScript) 中創建多級目錄或文件,可以使用鴻蒙的文件系統 API】

鴻蒙在 ETS (Extendable TypeScript) 中創建多級目錄或文件,可以使用鴻蒙的文件系統 API。

// 導入需要的模塊
import fs from '@ohos.file.fs';const TAG="Index"
@Entry
@Component
struct Index {@State message: string = 'Hello World';build() {Row() {Column() {Text(this.message).fontSize(50).fontWeight(FontWeight.Bold)Button("創建目錄").margin({ top: 10 }).onClick(() => {// 調用示例this.createDirsByRelativePath('path/to/your/dir');})Button("創建文件").margin({ top: 10 }).onClick(() => {// 調用示例this.createFile('path/to/your/dir/a.txt');})}.width('100%')}.height('100%')}/*** 創建文件* @param featurePath*/async createFile(featurePath:string){let mFeaturePath = "";if (featurePath.indexOf("/") != -1) {//創建目錄let lastAIndex = featurePath.lastIndexOf('/');let fFileDir: string = featurePath.slice(0, lastAIndex);let fileName: string = featurePath.slice(lastAIndex + 1);console.info(TAG, "arrPath:" + fFileDir);if (fFileDir.length != 0) {await this.createDirsByRelativePath(fFileDir);mFeaturePath = getContext(this).filesDir + fFileDir + "/" + fileName;} else {mFeaturePath = getContext(this).filesDir + "/" + fileName;}} else {mFeaturePath = getContext(this).filesDir + "/" + featurePath;}console.info(TAG, "mFeaturePath:" + mFeaturePath);}// 遞歸創建目錄async createMultiDirs(dirPath: string): Promise<void> {try {// 先檢查目錄是否存在let isExist = await fs.access(dirPath);if (isExist) {console.info(`Directory already exists: ${dirPath}`);return;}} catch (err) {// 如果目錄不存在,則繼續創建}// 獲取父目錄const parentDir = dirPath.substring(0, dirPath.lastIndexOf('/'));// 如果父目錄不是根目錄,且父目錄不存在,則遞歸創建父目錄if (parentDir && parentDir !== '/' && parentDir !== '') {try {// 檢查父目錄是否存在,如果不存在則遞歸創建await this.createMultiDirs(parentDir);} catch (err) {console.error(`Failed to create parent directory: ${parentDir}, error: ${JSON.stringify(err)}`);}}// 創建當前目錄try {await fs.mkdir(dirPath);console.info(`Directory created: ${dirPath}`);} catch (err) {// 如果錯誤碼為13900015(文件已存在),則忽略,否則拋出錯誤if (err.code !== 13900015) {console.error(`Failed to create directory: ${dirPath}, error: ${JSON.stringify(err)}`);}}}// 創建相對路徑的多級目錄(入口函數)async createDirsByRelativePath(relativePath: string): Promise<void> {const context = getContext();const baseDir = context.filesDir;const targetDir = baseDir + '/' + relativePath;try {await this.createMultiDirs(targetDir);console.info('All directories created successfully.');} catch (err) {console.error(`Failed to create directories: ${JSON.stringify(err)}`);}}// 創建多級目錄async createDirs(basePath: string, relativePath: string): Promise<boolean> {const fullPath = basePath + '/' + relativePath;try {await fs.mkdir(fullPath);console.info(`目錄創建成功: ${fullPath}`);return true;} catch (error) {console.error(`目錄創建失敗: ${JSON.stringify(error)}`);return false;}}// 創建文件(帶路徑自動創建)async createFileWithPath(basePath: string, filePath: string, content: string = ''): Promise<boolean> {const fullPath = basePath + '/' + filePath;try {// 分離目錄路徑和文件名const lastSlashIndex = filePath.lastIndexOf('/');const dirPath = lastSlashIndex > 0 ? filePath.substring(0, lastSlashIndex) : '';// 創建目錄(如果目錄路徑存在)if (dirPath) {await this.createDirs(basePath, dirPath);}// 創建文件并寫入內容const file = await fs.open(fullPath, fs.OpenMode.CREATE | fs.OpenMode.READ_WRITE);if (content) {await fs.write(file.fd, content);}await fs.close(file.fd);console.info(`文件創建成功: ${fullPath}`);return true;} catch (error) {console.error(`文件創建失敗: ${JSON.stringify(error)}`);return false;}}// 檢查文件是否存在async fileExists(basePath: string, filePath: string): Promise<boolean> {const fullPath = basePath + '/' + filePath;try {await fs.access(fullPath);return true;} catch {return false;}}
}

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/bicheng/84201.shtml
繁體地址,請注明出處:http://hk.pswp.cn/bicheng/84201.shtml
英文地址,請注明出處:http://en.pswp.cn/bicheng/84201.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

11. vue pinia 和react redux、jotai對比

對比 Vue 的 Pinia&#xff0c;和 React 的 Redux、Jotai&#xff0c;分中英文簡要介紹、特性、底層原理、使用場景。 簡單介紹 1.1 Pinia&#xff08;Vue&#xff09; ? 英文&#xff1a;Pinia is the official state management library for Vue 3, designed to be simple…

OPenCV CUDA模塊目標檢測----- HOG 特征提取和目標檢測類cv::cuda::HOG

操作系統&#xff1a;ubuntu22.04 OpenCV版本&#xff1a;OpenCV4.9 IDE:Visual Studio Code 編程語言&#xff1a;C11 算法描述 cv::cuda::HOG 是 OpenCV 的 CUDA 模塊中對 HOG 特征提取和目標檢測 提供的 GPU 實現。它與 CPU 版本的 cv::HOGDescriptor 類似&#xff0c;但利…

(一)單例模式

一、前言 單例模式屬于六大創建型模式,即在軟件設計過程中,主要關注創建對象的結果,并不關心創建對象的過程及細節。創建型設計模式將類對象的實例化過程進行抽象化接口設計,從而隱藏了類對象的實例是如何被創建的,封裝了軟件系統使用的具體對象類型。 六大創建型模式包括…

【QT】QT多語言切換

QT多語言切換 1.創建任意一個項目2. 利用lupdate&#xff08;language update&#xff09;工具生成.ts文件2.1 在工程中的.pro文件中指定.ts文件要存放的位置2.2 選擇工具--》外部--》Qt語言家--》更新翻譯 3. 利用 lrelease&#xff08;Language Release&#xff09;將 .ts 文…

【差分】詳解二維前綴和和差分問題

文章目錄 1. 二維前綴和2. 公式推導3. LeetCode 304 二維區域和檢索 - 矩陣不可變3.1 304 二維區域和檢索 - 矩陣不可變3.2 LeetCode 1139 最大的以 1 為邊界的正方形 4. 二維差分問題5. 二維差分的原理以及差分數組計算6. 題目6.1 牛客二維差分6.2 LeetCode 2132. 用郵票貼滿網…

Unity 大型手游碰撞性能優化指南

Unity 大型手游碰撞性能優化指南 版本: 2.1 作者: Unity性能優化團隊 語言: 中文 前言 在Unity大型手游的開發征途中,碰撞檢測如同一位隱形的舞者,它在游戲的物理世界中賦予物體交互的靈魂。然而,當這位舞者的舞步變得繁復冗余時,便會悄然消耗寶貴的計算資源,導致幀率下…

【hive】函數集錦:窗口函數、列轉行、日期函數

窗口函數 https://www.cnblogs.com/Uni-Hoang/p/17411313.html <窗口函數> OVER ([PARTITION BY <分組列> [, <分組列>...]][ORDER BY <排序列> [ASC | DESC] [, <排序列> [ASC | DESC]]...][<rows or range clause>]) )窗口函數主要是…

DAY 25 異常處理

目錄 DAY 25 異常處理1.異常處理機制2.debug過程中的各類報錯3.try-except機制4.try-except-else-finally機制作業&#xff1a;理解今日的內容即可&#xff0c;可以檢查自己過去借助ai寫的代碼是否帶有try-except機制&#xff0c;以后可以嘗試采用這類寫法增加代碼健壯性。 DAY…

幾何繪圖與三角函數計算應用

幾何繪圖與三角函數計算應用 設計思路 左側為繪圖控制面板&#xff0c;右側為繪圖區域支持繪制點、線、矩形、圓、多邊形等基本幾何圖形實現三角函數計算器&#xff08;正弦、余弦、正切等&#xff09;包含角度/弧度切換和常用數學常數歷史記錄功能保存用戶繪圖 完整實現代碼…

CSS 定位:原理 + 場景 + 示例全解析

一. 什么是CSS定位? CSS中的position屬性用于設置元素的定位方式,它決定了元素在頁面中的"定位行為" 為什么需要定位? 常規布局(如 display: block)適用于主結構 定位適用于浮動按鈕,彈出層,粘性標題等場景幫助我們精確控制元素在頁面中的位置 二. 定位類型全…

GESP 二級復習參考 A

本教程完整包含&#xff1a; 5000字詳細知識點解析 36個Python/C雙語言示例 15個GESP真題及模擬題 8張專業圖表和流程圖 # C編程二級標準終極教程## 一、計算機存儲系統深度解析### 1.1 存儲體系架構 mermaid graph TDA[CPU寄存器] --> B[L1緩存 1-2ns]B --> C[L2緩…

嵌入式面試常問問題

以下內容面向嵌入式/系統方向的初學者與面試備考者,全面梳理了以下幾大板塊,并在每個板塊末尾列出常見的面試問答思路,幫助你既能夯實基礎,又能應對面試挑戰。 一、TCP/IP 協議 1.1 TCP/IP 五層模型概述 鏈路層(Link Layer) 包括網卡驅動、以太網、Wi?Fi、PPP 等。負責…

【人工智能 | 項目開發】Python Flask實現本地AI大模型可視化界面

文末獲取項目源碼。 文章目錄 項目背景項目結構app.py(后端服務)index.html(前端界面)項目運行項目圖示項目源碼項目背景 隨著人工智能技術的快速發展,大語言模型在智能交互領域展現出巨大潛力。本項目基于 Qwen3-1.7B 模型,搭建一個輕量化的智能聊天助手,旨在為用戶提…

【設計模式】1.簡單工廠、工廠、抽象工廠模式

every blog every motto: You can do more than you think. https://blog.csdn.net/weixin_39190382?typeblog 0. 前言 以下是 簡單工廠模式、工廠方法模式 和 抽象工廠模式 的 Python 實現與對比&#xff0c;結合代碼示例和實際應用場景說明&#xff1a; 1. 簡單工廠模式&a…

瀏覽器訪問 AWS ECS 上部署的 Docker 容器(監聽 80 端口)

? 一、ECS 服務配置 Dockerfile 確保監聽 80 端口 EXPOSE 80 CMD ["nginx", "-g", "daemon off;"]或 EXPOSE 80 CMD ["python3", "-m", "http.server", "80"]任務定義&#xff08;Task Definition&…

01.SQL語言概述

SQL 語言概述 SQL &#xff08;Structured Query Language&#xff09;結構化査詢語言 1. 關系型數據庫的常見組件 數據庫: database 表的集合&#xff0c;物理上表現為一個目錄表: table&#xff0c;行: row 列: column索引: index視圖: view&#xff0c;虛擬的表存儲過程:…

C++學習-入門到精通【14】標準庫算法

C學習-入門到精通【14】標準庫算法 目錄 C學習-入門到精通【14】標準庫算法一、對迭代器的最低要求迭代器無效 二、算法1.fill、fill_n、generate和generate_n2.equal、mismatch和lexicographical_compare3.remove、remove_if、remove_copy和remove_copy_if4.replace、replace_…

Vue 項目實戰:三種方式實現列表→詳情頁表單數據保留與恢復

背景&#xff1a;在Vue項目中&#xff0c;實現列表頁跳轉詳情頁并保留表單數據&#xff0c;返回時恢復表單狀態。 核心功能&#xff1a; 保存緩存&#xff1a;點擊查詢按鈕時&#xff0c;表單數據保存恢復緩存&#xff1a;從詳情頁返回時&#xff0c;恢復表單數據清除緩存&…

iptables實驗

實驗一&#xff1a;搭建web服務&#xff0c;設置任何人能夠通過80端口訪問。 1.下載并啟用httpd服務器 dnf -y install httpd 開啟httpd服務器 systemctl start httpd 查看是否啟用 下載并啟用iptables&#xff0c;并關閉firewalld yum install iptable…

Razor編程RenderXXX相關方法大全

文章目錄 第一章&#xff1a;RenderXXX方法概述1.1 RenderXXX方法的作用與意義1.2 基本工作原理1.3 主要方法分類 第二章&#xff1a;部分視圖渲染方法2.1 Html.RenderPartial()2.2 Html.RenderAction()2.3 性能對比分析 第三章&#xff1a;視圖組件渲染方法3.1 Html.RenderCom…