آموزش Node.js: کار با فایل توسط ماژول fs – بخش نهم

۵۸۴
۱۴۰۲/۰۶/۱۸
۷ دقیقه
PDF
آموزش متنی جامع
امکان دانلود نسخه PDF

در این بخش از سری مقالات آموزش Node.js به بررسی روش کار با فایل‌ها با استفاده از ماژول fs می پردازیم. برای مطالعه بخش قبلی این مجموعه مطلب آموزشی، می‌توانید به لینک زیر مراجعه کنید:

آموزش Node.js: کار با فایل توسط ماژول fs – بخش نهمآموزش Node.js: کار با فایل توسط ماژول fs – بخش نهم
997696

پیش از آن که بتوانید با فایل‌هایی که در فایل‌سیستم شما قرار دارند، کار کنید باید یک توصیفگر فایل داشته باشید. «توصیفگر فایل» (File Descriptor) چیزی است که در زمان باز کردن فایل با متد ()OPEN در ماژول fs به دست می‌آید:

دقت کنید که ما از r به عنوان پارامتر دوم برای فراخوانی ()fs.open استفاده می‌کنیم. معنی این فلگ آن است که فایل برای خواندن باز شده است. فلگ‌های دیگر که به طور عمده استفاده می‌شوند، شامل موارد فهرست زیر هستند:

  • +r فایل را برای خواندن و نوشتن باز می‌کند.
  • +w فایل را برای خواندن و نوشتن باز می‌کند، استریم را در ابتدای فایل قرار می‌دهد. در صورتی که فایل موجود نباشد، ساخته می‌شود.
  • a فایل را برای نوشتن باز می‌کند، استریم را در انتهای فایل قرار می‌دهد. در صورتی که فایل موجود نباشد، آن را می‌سازد.
  • +a فایل را برای خواندن و نوشتن باز می‌کند، استریم را در انتهای فایل قرار می‌دهد. در صورتی که فایل موجود نباشد، آن را می‌سازد.

همچنین می‌توان فایل را با استفاده از متد fs.openSync باز کرد که به جای ارائه شیء توصیفگر فایل در یک callback آن را به صورت زیر بازگشت می‌دهد:

زمانی که توصیفگرِ فایل خود را به هر طریقی که تشخیص می‌دهید، به دست آوردید، می‌توانید همه عملیاتی که نیاز دارد مانند ()fs.open و بسیاری عملیات دیگر را که با فایل‌سیستم تعامل دارند اجرا کنید.

آمار فایل در Node.js

هر فایل مجموعه‌ای جزییات دارد که می‌توان با استفاده از Node.js آن‌ها را بازبینی کرد.

به طور خاص استفاده از متد ()start که از سوی ماژول fs ارائه شده به این منظور مفید است. می‌توان مسیر فایل را به این متد ارسال کرد و زمانی که Node.js جزییات فایل را دریافت کرد، تابع callback را با 2 پارامتر فراخوانی می‌کند. این پارامترها شامل یک پیام خطا و آمار فایل است:

Node.js همچنین یک متد sync عرضه می‌کند که نخ را تا زمانی که آمار فایل آماده نشده است، مسدود می‌کند:

این اطلاعات در متغیر stats ذخیره می‌شوند. بدین ترتیب می‌توانیم اطلاعات زیادی در مورد فایل به دست آوریم که برخی از آن‌ها در ادامه فهرست شده‌اند:

  • با استفاده از ()stats.isFile و ()stats.isDirectory بررسی می‌کنیم آیا فایل واقعاً یک فایل است یا یک دایرکتوری است.
  • اگر فایل یک «پیوند نمادین» (symbolic link) باشد با استفاده از ()stats.isSymbolicLink آن را بررسی می‌کنیم.
  • با استفاده stats.size اندازه فایل را بر حسب بایت بررسی می‌کنیم.

متدهای پیشرفته دیگری نیز وجود دارند، اما عمده مواردی که به صورت روزمره استفاده می‌شوند، به صورت زیر است:

مسیرهای فایل در Node.js

هر فایل در سیستم یک مسیر دارد. روی لینوکس و macOS مسیر به صورت زیر است:

/users/flavio/file.txt

روی رایانه‌های ویندوزی مسیر متفاوت است و ساختاری مانند زیر دارد:

C:\users\flavio\file.txt

بدین ترتیب زمانی که از مسیرها در اپلیکیشن خود استفاده می‌کنید باید به این تفاوت توجه داشته باشید و آن را در نظر بگیرید. با استفاده از دستور زیر این ماژول را در فایل‌های خود بگنجانید:

بدین ترتیب می‌توانید از متدهای آن استفاده کنید.

دریافت اطلاعات از یک مسیر

با فرض وجود یک مسیر برای فایل، می‌توان اطلاعاتی را در مورد آن با استفاده از این متدها استخراج کرد:

  • Dirname – پوشه والد فایل را دریافت می‌کند.
  • Basename – بخش نام فایل را از مسیر فایل دریافت می‌کند.
  • Extname – بخش نام پسوند فایل را استخراج می‌کند.

به مثال زیر توجه کنید:

نام فایل را می‌توان بدون پسوند و از طریق تعیین آرگومان دوم به صورت basename به دست آورد:

کار با مسیرها

می‌توان دو یا چند بخش از یک مسیر را با استفاده از متد ()path.join با هم ترکیب کرد:

می‌توان مسیر مطلق یک فایل را از روی مسیر نسبی آن با استفاده از متد ()path.resolve محاسبه کرد:

در این حالت Node.js به سادگی flavio.txt/ را به دایرکتوری کاری جاری پیوست می‌کند. اگر در پارامتر دوم نام یک پوشه را ذکر کنید، resolve از آرگومان نخست به عنوان مبنایی برای دوم استفاده می‌کند:

اگر پارامتر اول با یک اسلش (/) آغاز شود، این بدان معنی است که یک مسیر مطلق است:

یک تابع مفید دیگر ()path.normalize است که تلاش می‌کند مسیر واقعی را از روی توصیف‌کننده‌های نسبی مانند . یا .. یا اسلش‌های دوبل (//) محاسبه کند:

اما resolve و normalize بررسی نمی‌کنند که آیا مسیر وجود دارد یا نه. آن‌ها صرفاً مسیر را بر مبنای اطلاعاتی که شما ارائه می‌کنید محاسبه می‌کنند.

خواندن فایل‌ها با Node.js

ساده‌ترین روش برای خواندن یک فایل در Node.js استفاده از متد ()fs.readFile است که مسیر نخست و یک تابع callback به آن ارسال می‌شود و با داده‌های فایل (و خطا) فراخوانی می‌شود:

به طور جایگزین می‌توانید از نسخه ناهمگام آن یعنی ()fs.readFileSync نیز استفاده کنید:

انکودینگ پیش‌فرض در زمان خواندن فایل utf8 است، اما می‌توان انکودینگ خاصی را با استفاده از پارامتر دوم تعیین کرد. هر دو متد ()fs.readFile و ()fs.readFileSync پیش از بازگشت دادن داده‌ها، محتوای کامل فایل را در حافظه می‌خوانند.

این بدان معنی است که فایل‌ها می‌توانند تأثیر زیادی روی مصرف حافظه و سرعت اجرای برنامه داشته باشند. در این حالت، گزینه بهتر می‌تواند خواندن محتوای فایل با استفاده از «استریم» (Stream) باشد.

نوشتن فایل‌ها در Node.js

آسان‌ترین روش برای نوشتن فایل‌ها در Node.js استفاده از API به نام ()fs.writeFile است. به مثال زیر توجه کنید:

به طور جایگزین می‌توانید از نسخه ناهمگام آن یعنی ()fs.writeFileSync نیز استفاده کنید:

این API به صورت پیش‌فرض، در صورت وجود داشتن فایل، محتوای آن را عوض می‌کند. شما می‌توانید با استفاده از فلگ‌های زیر این رفتار را عوض کنید:

فلگ‌هایی که می‌توان استفاده کرد به شرح زیر هستند:

  • +r فایل را برای خواندن و نوشتن باز می‌کند.
  • +w فایل را برای خواندن و نوشتن باز می‌کند و استریم را در ابتدای فایل قرار می‌دهد. در صورتی که فایل وجود نداشته باشد، آن را ایجاد می‌کند.
  • a فایل را برای خواندن و نوشتن باز می‌کند و استریم را در انتهای فایل قرار می‌دهد. در صورتی که فایل وجود نداشته باشد، آن را ایجاد می‌کند.
  • +a فایل را برای خواندن و نوشتن باز می‌کند و استریم را در انتهای فایل قرا می‌دهد. در صورتی که فایل وجود نداشته باشد، آن را ایجاد می‌کند.

الحاق محتوایی به فایل

یک متد کارآمد برای الحاق محتوا به انتهای یک فایل ()fs.appendFile و متد همتای آن ()fs.appendFileSync است:

استفاده از استریم‌ها

همه این متدها محتوای کامل فایل را پیش از بازگشت دادن کنترل به برنامه می‌نویسند (در نسخه sync این بدان معنی است که callback اجرا می‌شود). در این حالت یک گزینه بهتر، نوشتن محتوای فایل با استفاده از استریم است.

کار با پوشه‌ها در Node.js

ماژول مرکزی fs در Node.js متدهای کارآمد زیادی ارائه می‌کند که می‌توان برای کار با پوشه‌ها مورد استفاده قرار داد.

بررسی وجود یک پوشه

با استفاده از ()fs.access می‌توان بررسی کرد که آیا یک پوشه وجود دارد یا نه و Node.js می‌تواند با مجوزهای خود به آن دسترسی یابد.

ایجاد یک پوشه جدید

از ()fs.mkdir یا ()fs.mkdirSync برای ایجاد یک پوشه جدید استفاده کنید:

خواندن محتوای یک پوشه

از ()fs.readdir یا ()fs.readdirSync برای خواندن محتوای یک دایرکتوری استفاده کنید. این قطعه کد محتوای یک پوشه را می‌خواند. این مسیر شامل فایل‌ها و زیرپوشه‌ها نیز می‌شود و مسیر نسبی آن‌ها را بازگشت می‌دهد:

مسیر کامل را می‌توان به صورت زیر به دست آورد:

همچنین می‌توان نتایج را طوری فیلتر کرد که تنها فایل‌ها بازگشت یابند و پوشه‌ها حذف شوند:

تغییر دادن نام یک پوشه

با استفاده از متدهای ()fs.rename یا ()fs.renameSync می‌توان نام یک پوشه را تغییر داد. پارامتر اول مسیر جاری و پارامتر دوم مسیر جدید است:

متد ()fs.renameSync نسخه ناهمگام است:

حذف کردن یک پوشه

با استفاده از ()fs.rmdir یا ()fs.rmdirSync می‌توان یک پوشه را حذف کرد. حذف کردن یک پوشه که محتوایی دارد ممکن است پیچیده‌تر از چیزی باشد که نیاز دارید.

در این حالت پیشنهاد می‌کنیم ماژول fs-extra را نصب کنید که بسیار محبوب است و به خوبی نگهداری می‌شود. این ماژول یک جایگزین قطعی برای ماژول fs است که بر مبنای آن ساخته شده و قابلیت‌های بیشتری ارائه می‌کند.

در این حالت متد ()remove می‌تواند برای حذف فایل استفاده شود. ابتدا آن را با استفاده از دستور زیر نصب کنید:

npm install fs-extra

استفاده از آن نیز به صورت زیر است:

همچنین می‌توان با استفاده از Promise-ها از آن استفاده کرد:

یا می‌توان از async/await استفاده کرد:

بدین ترتیب به پایان این نوشته با موضوع روش کار با فایل در Node.js می‌رسیم. Node.js ماژول‌های مفید زیاد دیگری نیز دارد که در بخش‌های بعدی این سری مقالات به بررسی آن‌ها نیز خواهیم پرداخت. برای مطالعه بخش بعدی به لینک زیر مراجعه کنید:

اگر این مطلب برای شما مفید بوده است، آموزش‌های زیر نیز به شما پیشنهاد می‌شوند:

==

بر اساس رای ۱ نفر
آیا این مطلب برای شما مفید بود؟
اگر پرسشی درباره این مطلب دارید، آن را با ما مطرح کنید.
منابع:
freecodecamp
PDF
مطالب مرتبط
۱ دیدگاه برای «آموزش Node.js: کار با فایل توسط ماژول fs – بخش نهم»

سلام. من به این طریق یه پوشه داخل یوزر هاستم ساختم. اما سازنده پوشه رو زده root و از طریق یوزر امکان دسترسی و حذف و … نداره.

نظر شما چیست؟

نشانی ایمیل شما منتشر نخواهد شد. بخش‌های موردنیاز علامت‌گذاری شده‌اند *