ホームページ > ウェブフロントエンド > jsチュートリアル > Node.js ファイル システムの操作

Node.js ファイル システムの操作

php中世界最好的语言
リリース: 2018-04-18 15:16:38
オリジナル
1667 人が閲覧しました

今回は、Node.jsファイルシステムの操作について説明します。Node.jsファイルシステム操作の注意事項は何ですか。以下は実際的なケースです。見てみましょう。

1. 同期メソッドと非同期メソッド

Node.js では、fs モジュールを使用して、関連するすべてのファイルとディレクトリの作成、書き込み、削除の操作を実装します。 , fs モジュールでは、ファイルとディレクトリに対するすべての操作で同期メソッドと非同期メソッドの両方を使用できます。 2 つの違いは、同期メソッドは操作結果をすぐに返し、同期メソッドを使用して実行された操作が完了するまでは後続のコードを実行できないことです。コードは次のようになります。 非同期メソッドは、コールバック

関数のパラメータ

として操作結果を返します。コードは次のとおりです。 また、以下のメソッドで複数の非同期メソッドを呼び出した場合、演算結果が返される順序は保証されません

上記のコードでは、2 つのファイルに対して読み取り操作を同時に実行しますが、どちらの操作結果が最初に返されるかは保証されません。 1 つの引用が読み取られた後に 2 つのファイルが確実に読み取られるようにしたい場合は、次のメソッドを使用する必要があります:

var fs = require('fs')
fs.readFile('./index.html','utf8'.function(err,data){
  //操作结果作为回调函数的第二个参数返回
  console.log(data)
})
ログイン後にコピー

2. ファイルの読み取りおよび書き込み操作を実行します

2.1 ファイルの読み取りと書き込みを完了する

readFile メソッドまたは readFileSync メソッドを使用して、ファイルを完全に読み取ることができます:

fs.readFile('./file.html',function(err,data){
  //回调函数代码
  })
fs.readFile('./otrher.html',function(err,data){
  //回调函数代码
  })
ログイン後にコピー

同期メソッドを使用してファイルを読み取る場合は、readFileSync メソッドを使用します:

fs.readFileSync('./file.html',function(err,data){
  //回调函数代码
  })
fs.readFileSync('./otrher.html',function(err,data){
  //回调函数代码
  })
ログイン後にコピー

例:

りー

ファイルを完全に書き込む場合は、fs モジュールの writeFile メソッドまたは writeFileSync メソッドを使用します

fs.readFile(filename,[options],callback)
//第一个参数:必选指定读取文件的完整文件路径及文件名
第二个参数:指定读取文件时需要使用的选项,在该参数值对象中可以使用flag属性指定对该文件采取什么操作,默认为‘r'
option:
  flag'r':读取文件,如果文件不存在则抛出异常
    'r+':读取并写入文件,如果文件不存在则抛出异常
    'rs':以同步方式读取文件并通知操作系统忽略本地文件系统缓存,如果文件不存在则抛出异常。因为本属性值忽略本地缓存,适用于操作网络文件系统,但由于其对性能产生一定的负面影响,不建议在其他环境下使用
    'w':写入文件,如果文件不存在则创建文件,如果文件存在则清空文件内容
    'wx':作用与'w'类似,但以排他方式写入文件
    'w+':读取并写入文件。如果不存在则创建文件,如果该文件已存在则清空文件内容       
    'wx+':作用与'w+'类似,但是以排他方式写入文件       
    'a':追加写入文件,如果文件不存在则创建文件
    'ax':作用与'a+'类似,但是以排他方式打开文件
  encoding:
    utf8,ascii,base64,
callback(err,data){
  //回调函数代码略
}
//第一个参数为读取文件操作失败时触发的错误对象
第二个参数值为读取到的文件内容
ログイン後にコピー

ファイルを同期的に書き込む場合は、writeFileSync メソッドを使用します:

var data = fs.readFileSync(filename,[options])
ログイン後にコピー

バッファー内の文字列またはデータをファイルの最後に追加する場合、fs モジュールの appendFile または appendFildSync メソッドを使用できます

var fs = require('fs')
try{
  var data = fs.readFileSync('./text.txt','utf8')
  //在控制台中输出文件内容
  console.log(data) 
}catch(ex){
  console.log('读取文件时发生错误')
}
ログイン後にコピー

2.2 指定した場所からファイルの読み取りと書き込みを開始します

まず、fs モジュールの open メソッドまたは openSync メソッドを使用してファイルを開く必要があります

fs.writeFile(filename,datda,[options],callback)
//第一个参数:用于指定被写入文件的完整文件路径及文件名
第二个参数:用于指定需要写入的内容,参会素可以为一个字符串或一个Buffer对象
第三个参数:指定写入文件时需要的选项
    flag属性:用于指定该文件采用何种操作,默认为'w'
    mode属性:指定当文件被打开时对文件的读写权限,默认为0666(可读写),第一位必须为0,第二位用于规定文件或目录所有者的权限,第三位为文件或目录所属用户组的权限,第四位为其他用户权限
      1:执行权限
      2:写权限
      4:读权限
    encoding属性:指定使用何种编码格式来写入文件,:utf8 ascii base64
    
callback(err){
  //回调函数代码
}
ログイン後にコピー

ファイルを同期的に開く場合は、openSync メソッドを使用します:

fs.writeFileSync(filename,data,[options])
ログイン後にコピー

ファイルを開いた後、コールバック関数の fs モジュールの read メソッドまたは readSync メソッドを使用して、ファイルの指定された場所からファイルを読み取ることができます。また、fs モジュールの write メソッドまたは writeSync メソッドを使用して開始することもできます。ファイルの指定された場所から書き込みます

まず読み取りメソッドを紹介します:

fs.appendFile(filname,data,[options],callback)
fs.appendFileSync(filename,data[options])
ログイン後にコピー

ファイルを同期的に開く場合は、readSync メソッドを使用します:

fs.open(filename,flags,[mode],callback)
其中callback参数为:function(err,fd){
            //回调函数代码
          }
//第一个参数为打开文件操作失败时所触发的错误对象,
第二个参数为一个整数值,代表打开文件时返回的文件描述符
ログイン後にコピー

ファイルを開いた後、fs モジュールの write メソッドまたは writeSync メソッドを使用してバッファからデータを読み取り、ファイルの指定された位置からデータの取り込みを開始します

var fd = fs.openSync(filename,flag,[mode])
ログイン後にコピー

ファイルを同期的に書き込む場合は、writeSync メソッドを使用します

fs.read(fd,buffer,offset,length,position,callback)
//第一个参数:open方法所所使用的回调函数中返回的文件描述符或openSync方法返回的文件描述符;
第二个参数:英语指定将文件数据读取到哪个缓存区;
第三个参数:整数,用于指定向缓存区中写入数据时的开始位置,以字节为单位
第四个参数:整数,指定从文件中读取的字节数
第五个参数:整数,指定读取文件时开始位置
callback(err,bytesRead,buffer){
  //回调函数代码
}
err:读取文件操作失败时触发的错误对象
bytesRead实际读取的字节数
buffer:被读取的缓存区对象
ログイン後にコピー

fs モジュールで、close メソッドと closeSync メソッドを使用してファイルを閉じます

var byteRead = fs.readSync(fd,buffer,offset,length,position)
ログイン後にコピー

CLOSE メソッドを呼び出す前に、FSYN メソッドを使用してキャッシュ領域のすべての内容をファイルに書き込むことで、データの欠落を防ぐことができます。

fs.write(fd,buffer,offset,length,position,callback)
  其中callback为function(err,written,buffer){
            //回调函数代码
        }
eg:
 1 var fs = require('fs')
 2 var buf = new Buffer('我喜欢编程')
 3 fs.open('./message.txt','w',function(err,fd){
 4     fs.write(fd,buf,3,9,0,function(err,written,buffer){
 5         if(err)console.log("写文件操作失败")
 6         console.log("写文件操作成功")
 7     })
 8 })
ログイン後にコピー

この記事の方法を習得したことを信じてください。さらに興味深い内容については、以下を参照してください。 PHP のその他の関連記事!

推奨読書:

HTMLタグとDOMノードの結合

JSの暗黙的な型変換の概要

以上がNode.js ファイル システムの操作の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート