9

我有一个小脚本在每 4 个字符后拆分 'var foo' 内的文本。它工作正常。但我的实际数据在一个文本文件中,比如“a.txt”。如何在“var foo”中获取整个文件文本。并将拆分输出写入另一个文本文件?

var foo = "this is sample text !!!"; 
var arr = [];
for (var i = 0; i < foo.length; i++) {
    if (i % 4 == 0 && i != 0)
        arr.push(foo.substring(i - 4, i));
    if (i == foo.length - 1)
        arr.push(foo.substring(i - (i % 4), i+1));          
}
document.write(arr);
console.log(arr);
4

2 回答 2

8

要获取文件的内容,您需要使用输入标签选择文件。

<!DOCTYPE html>
<head>
  <meta charset="UTF-8">
</head>
<body>
  <input id="input" type="file" accept="text/plain">
  <script src="script.js"></script>
</body>

阅读文件内容的好时机是在更改事件中。

const input = document.querySelector("#input");

input.addEventListener("change", () => {
  const file = input.files.item(0);
});

要将文件的内容作为字符串读取,您需要对其进行转换。

function fileToText(file, callback) {
  const reader = new FileReader();
  reader.readAsText(file);
  reader.onload = () => {
    callback(reader.result);
  };
}

文件内容作为字符串将可用于回调函数。您可以创建一个链接并使用单击事件将字符串下载到文本文件中。

function save(content, fileName, mime) {
  const blob = new Blob([content], {
    tipe: mime
  });
  const url = URL.createObjectURL(blob);
  const a = document.createElement("a");
  a.href = url;
  a.download = fileName;
  a.click();
}

这是完整的代码

const input = document.querySelector("#input");

input.addEventListener("change", () => {
  const file = input.files.item(0);
  fileToText(file, (text) => {
    save(text, "fileName.txt", "text/plain");
  });
});

function fileToText(file, callback) {
  const reader = new FileReader();
  reader.readAsText(file);
  reader.onload = () => {
    callback(reader.result);
  };
}

function save(content, fileName, mime) {
  const blob = new Blob([content], {
    tipe: mime
  });
  const url = URL.createObjectURL(blob);
  const a = document.createElement("a");
  a.href = url;
  a.download = fileName;
  a.click();
}
<!DOCTYPE html>

<head>
  <meta charset="UTF-8">
</head>

<body>
  <input id="input" type="file" accept="text/plain">
  <script src="script.js"></script>
</body>

您可以在此处阅读有关在 JavaScript 中操作文件的更多信息:https ://www.html5rocks.com/en/tutorials/file/dndfiles/

于 2017-04-14T01:44:18.490 回答
3

对此的解决方案帮助了我:

如何将文本文件的内容加载到 javascript 变量中?

var client = new XMLHttpRequest();
client.open('GET', '/foo.txt');
client.onreadystatechange = function() {
alert(client.responseText);
}
client.send();
于 2020-09-08T08:39:51.303 回答