Odpowiedzi:
Zgodnie z komentarzem seppo0010, użyłem do tego funkcji zmiany nazwy.
http://nodejs.org/docs/latest/api/fs.html#fs_fs_rename_oldpath_newpath_callback
fs.rename (stara ścieżka, nowa ścieżka, wywołanie zwrotne)
Dodano w: v0.0.2
oldPath <String> | <Buffer> newPath <String> | <Buffer> callback <Function>
Asynchroniczna zmiana nazwy (2). Żadne inne argumenty niż możliwy wyjątek nie są podawane do wywołania zwrotnego zakończenia.
Ten przykład pochodzi z: Node.js w akcji
Funkcja move (), która zmienia nazwę, jeśli to możliwe, lub wraca do kopiowania
var fs = require('fs');
module.exports = function move(oldPath, newPath, callback) {
fs.rename(oldPath, newPath, function (err) {
if (err) {
if (err.code === 'EXDEV') {
copy();
} else {
callback(err);
}
return;
}
callback();
});
function copy() {
var readStream = fs.createReadStream(oldPath);
var writeStream = fs.createWriteStream(newPath);
readStream.on('error', callback);
writeStream.on('error', callback);
readStream.on('close', function () {
fs.unlink(oldPath, callback);
});
readStream.pipe(writeStream);
}
}
Używanie nodejs natywnie
var fs = require('fs')
var oldPath = 'old/path/file.txt'
var newPath = 'new/path/file.txt'
fs.rename(oldPath, newPath, function (err) {
if (err) throw err
console.log('Successfully renamed - AKA moved!')
})
(UWAGA: „To nie zadziała, jeśli przechodzisz przez partycje lub używasz wirtualnego systemu plików nieobsługującego przenoszenia plików. [...]” - Flavien Volken 2 września 15 o 12:50 ”)
Użyj modułu węzła mv , który najpierw spróbuje wykonać, fs.rename
a następnie powrócić do kopiowania i rozłączenia.
mv
modułu węzła. Lubię używać npm do instalacji; npm install mv --save-dev
; tutaj jest link npm
util.pump
jest przestarzały w węźle 0.10 i generuje komunikat ostrzegawczy
util.pump() is deprecated. Use readableStream.pipe() instead
Tak więc rozwiązanie do kopiowania plików za pomocą strumieni to:
var source = fs.createReadStream('/path/to/source');
var dest = fs.createWriteStream('/path/to/dest');
source.pipe(dest);
source.on('end', function() { /* copied */ });
source.on('error', function(err) { /* error */ });
Korzystanie z funkcji zmiany nazwy:
fs.rename(getFileName, __dirname + '/new_folder/' + getFileName);
gdzie
getFilename = file.extension (old path)
__dirname + '/new_folder/' + getFileName
zakładając, że chcesz zachować niezmienioną nazwę pliku.
fs-extra
Moduł pozwala to zrobić z jego move()
metodą. Już to zaimplementowałem i działa dobrze, jeśli chcesz całkowicie przenieść plik z jednego katalogu do drugiego - tj. usunięcie pliku z katalogu źródłowego. Powinien działać w większości podstawowych przypadków.
var fs = require('fs-extra')
fs.move('/tmp/somefile', '/tmp/does/not/exist/yet/somefile', function (err) {
if (err) return console.error(err)
console.log("success!")
})
Oto przykład użycia util.pump, z >> Jak przenieść plik a na inną partycję lub urządzenie w Node.js?
var fs = require('fs'),
util = require('util');
var is = fs.createReadStream('source_file')
var os = fs.createWriteStream('destination_file');
util.pump(is, os, function() {
fs.unlinkSync('source_file');
});
fs.rename()
(w obrębie woluminu zmiana nazwy pliku i przeniesienie go to to samo).
Korzystanie z obietnic dla wersji węzła wyższych niż 8.0.0:
const {promisify} = require('util');
const fs = require('fs');
const {join} = require('path');
const mv = promisify(fs.rename);
const moveThem = async () => {
// Move file ./bar/foo.js to ./baz/qux.js
const original = join(__dirname, 'bar/foo.js');
const target = join(__dirname, 'baz/qux.js');
await mv(original, target);
}
moveThem();
fs.rename
nie zadziała, jeśli jesteś w środowisku Docker z woluminami.
async
deklarację do moveThem
funkcji.
Tylko moje 2 centy, jak stwierdzono w powyższej odpowiedzi : Metoda copy () nie powinna być używana do kopiowania plików bez niewielkiej korekty:
function copy(callback) {
var readStream = fs.createReadStream(oldPath);
var writeStream = fs.createWriteStream(newPath);
readStream.on('error', callback);
writeStream.on('error', callback);
// Do not callback() upon "close" event on the readStream
// readStream.on('close', function () {
// Do instead upon "close" on the writeStream
writeStream.on('close', function () {
callback();
});
readStream.pipe(writeStream);
}
Funkcja kopiowania zawarta w obietnicy:
function copy(oldPath, newPath) {
return new Promise((resolve, reject) => {
const readStream = fs.createReadStream(oldPath);
const writeStream = fs.createWriteStream(newPath);
readStream.on('error', err => reject(err));
writeStream.on('error', err => reject(err));
writeStream.on('close', function() {
resolve();
});
readStream.pipe(writeStream);
})
Należy jednak pamiętać, że system plików może ulec awarii, jeśli folder docelowy nie istnieje.
Chciałbym oddzielić wszystkich zaangażowanych funkcje (tj rename
, copy
, unlink
) od siebie, aby zyskać elastyczność i promisify wszystko, oczywiście:
const renameFile = (path, newPath) =>
new Promise((res, rej) => {
fs.rename(path, newPath, (err, data) =>
err
? rej(err)
: res(data));
});
const copyFile = (path, newPath, flags) =>
new Promise((res, rej) => {
const readStream = fs.createReadStream(path),
writeStream = fs.createWriteStream(newPath, {flags});
readStream.on("error", rej);
writeStream.on("error", rej);
writeStream.on("finish", res);
readStream.pipe(writeStream);
});
const unlinkFile = path =>
new Promise((res, rej) => {
fs.unlink(path, (err, data) =>
err
? rej(err)
: res(data));
});
const moveFile = (path, newPath, flags) =>
renameFile(path, newPath)
.catch(e => {
if (e.code !== "EXDEV")
throw new e;
else
return copyFile(path, newPath, flags)
.then(() => unlinkFile(path));
});
moveFile
to tylko wygodna funkcja, którą możemy zastosować osobno, gdy na przykład potrzebujemy dokładniejszej obsługi wyjątków.
Shelljs to bardzo przydatne rozwiązanie.
polecenie: mv ([opcje,] źródło, cel)
Dostępne opcje:
-f: force (domyślne zachowanie)
-n: aby zapobiec nadpisywaniu
const shell = require('shelljs');
const status = shell.mv('README.md', '/home/my-dir');
if(status.stderr) console.log(status.stderr);
else console.log('File moved!');
jest to powtórzenie odpowiedzi Teomana Shipahiego z nieco mniej niejednoznaczną nazwą i zgodnie z zasadą projektową definiowania kodu, zanim spróbujesz go wywołać. (Chociaż węzeł pozwala zrobić inaczej, stawianie wózka przed koniem nie jest dobrą praktyką).
function rename_or_copy_and_delete (oldPath, newPath, callback) {
function copy_and_delete () {
var readStream = fs.createReadStream(oldPath);
var writeStream = fs.createWriteStream(newPath);
readStream.on('error', callback);
writeStream.on('error', callback);
readStream.on('close',
function () {
fs.unlink(oldPath, callback);
}
);
readStream.pipe(writeStream);
}
fs.rename(oldPath, newPath,
function (err) {
if (err) {
if (err.code === 'EXDEV') {
copy_and_delete();
} else {
callback(err);
}
return;// << both cases (err/copy_and_delete)
}
callback();
}
);
}
Za pomocą poniższego adresu URL możesz skopiować lub przenieść plik CURRENT Source do Destination Source
/*********Moves the $file to $dir2 Start *********/
var moveFile = (file, dir2)=>{
//include the fs, path modules
var fs = require('fs');
var path = require('path');
//gets file name and adds it to dir2
var f = path.basename(file);
var dest = path.resolve(dir2, f);
fs.rename(file, dest, (err)=>{
if(err) throw err;
else console.log('Successfully moved');
});
};
//move file1.htm from 'test/' to 'test/dir_1/'
moveFile('./test/file1.htm', './test/dir_1/');
/*********Moves the $file to $dir2 END *********/
/*********copy the $file to $dir2 Start *********/
var copyFile = (file, dir2)=>{
//include the fs, path modules
var fs = require('fs');
var path = require('path');
//gets file name and adds it to dir2
var f = path.basename(file);
var source = fs.createReadStream(file);
var dest = fs.createWriteStream(path.resolve(dir2, f));
source.pipe(dest);
source.on('end', function() { console.log('Succesfully copied'); });
source.on('error', function(err) { console.log(err); });
};
//example, copy file1.htm from 'test/dir_1/' to 'test/'
copyFile('./test/dir_1/file1.htm', './test/');
/*********copy the $file to $dir2 END *********/
Jeśli próbujesz przenieść lub zmienić nazwę pliku źródłowego node.js, spróbuj tego https://github.com/viruschidai/node-mv . Zaktualizuje odniesienia do tego pliku we wszystkich innych plikach.
Możesz skorzystać z move-file
pakietu npm:
Najpierw zainstaluj pakiet:
$ npm install move-file
Stosowanie:
const moveFile = require('move-file');
// moveFile Returns a Promise that resolves when the file has been moved
moveFile('source/unicorn.png', 'destination/unicorn.png')
.then(() => {/* Handle success */})
.catch((err) => {/* Handle failure */});
// Or use async/await
(async () => {
try {
await moveFile('source/unicorn.png', 'destination/unicorn.png');
console.log('The file has been moved');
} catch (err) {
// Handle failure
console.error(err);
}
})();