- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用 Javascript FileReader。我想读入 FileReader 的结果,然后将每条记录转换为 JS 对象。使用以下代码:
$("#csv").bind("change", function (event) {
var reader = new FileReader();
reader.onload = function (theFile) {
try {
var input = $.csv.toArrays(theFile.target.result);
alert("CSV loaded successfully");
alert(input);
}
catch (e) {
alert("CSV Parse error.");
return;
}
};
reader.readAsText(event.target.files[0]);
});
}
alert(input)
会将整个 csv 文件显示为字符串。我将如何从这个输入创建一个 javascript 对象数组或 JSON 字符串?换句话说,我假设我需要在第一行中读取属性集,然后每条记录都会创建一个具有该属性集的对象,并将这些对象中的每一个插入到一个数组中。
例如,来自以下字符串:
姓名、年龄、性别
约翰,20岁,男
我想创建一个对象:
{ Name: "John", Age: 20, Gender: "Male" }
提前致谢!
最佳答案
使用正则表达式
/[\w .]+(?=,?)/g
您可以按照您提到的格式从 csv 文件中提取数据(如果 .csv 文件和数据的格式不同,则需要更改 RegEx)。
示例数据。给定格式
Name,Age,Gender
John,20,Male
Cristine ,34,FeMale
Kate Wilson,65, FeMale
Mike,45,Male
Peter,23,Male
Katty,11,FeMale
Sandy,78,Mal
代码
var str = $('#regex_string').val();
var extractValidString = str.match(/[\w .]+(?=,?)/g)
var noOfCols = 3
//in your case it is name,age,gender so we need 3
var objFields = extractValidString.splice(0,noOfCols);
//extract columns - First Row
var arr = [];
while(extractValidString.length>0) {
var obj = {};
//extract remaining rows one by one
var row = extractValidString.splice(0,noOfCols)
for(var i=0;i<row.length;i++) {
//make an object and put each column and set its data
obj[objFields[i]] = row[i].trim()
}
//push row to an array
arr.push(obj)
}
console.log(arr);
//output
[Object, Object, Object, Object, Object, Object, Object]
0: Object
Age: "20"
Gender: "Male"
Name: "John"
1: Object
Age: "34"
Gender: "FeMale"
Name: "Cristine"
2: Object
Age: "65"
Gender: "FeMale"
Name: "Kate Wilson"
3: Object
Age: "45"
Gender: "Male"
Name: "Mike"
4: Object
Age: "23"
Gender: "Male"
Name: "Peter"
5: Object
Age: "11"
Gender: "FeMale"
Name: "Katty"
6: Object
Age: "78"
Gender: "Male"
Name: "Sandy"
length: 7
关于javascript - 将 FileReader 的结果转换为 javascript 对象,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24587617/
第一次在这里发帖。 我正在编写一个 Java 程序,它接受一个输入文本文件,读取内容,然后将它们打印到屏幕上,同时创建一个包含内容的输出文件。我已经设置了必要的编写器,但是当我尝试使用 Buffere
类 FileReader 中的构造函数 FileReader 不能应用于给定类型; import java.io.*; public class FileReader{ publ
任何人都可以帮我修复我的代码,以便我可以编译它。 当我编译它时,会出现一条错误消息“对‘FileReader::FileReader()’的 undefined reference ”。 #ifnde
这是我的程序。我必须从 JFileChooser 选择一个文件,然后对其执行一些操作。问题是,在我选择文件之前,filereader 给出了 nullpointer ,说实话,我什至无法选择,因为当
我无法真正理解 Java 中 FileReader 和 BufferedReader 类的用途。 在 docs.oracle 中,建议将缓冲读取器包装在 FileReader 对象周围,因为直接使用
我正在尝试读取 CSV 或 Excel 文件以将其转换为表格。现在我刚刚创建了一个类来读取输入文件: 输入是: 现在我刚刚创建了一个类来读取输入文件: class InputReader_tiqe
我正在玩弄食物识别 API。 我有一个名为 ingredients 的本地状态组件。 在组件中,我有一个 input 标签,它接受文件图像上传并调用 cameraHandler 方法 onChange
我正在尝试使用此应用脚本将文件上传到 Google 云端硬盘,它适用于较小的文件,但在上传大于约 1 GB 的文件时失败 + 一旦加载大文件,onerror 函数就会执行。我无法弄清楚如何在切片中读取
我的代码 - $selectFile = $(''); $selectFile.click(function () { this.value = null; });
我有一个 FileReader,可以让用户将文件(图像)上传到我的网站。 这是执行读取的代码: $("input[type='file']").change(function(e) { var
我知道异步方法应该是非阻塞的。但我通常看到它们应用于诸如 fetch() 之类的外部操作。 即:在浏览器外部处理的内容。 但是 FileReader() API 又如何呢?文件处理是由浏览器完成的,对
我有(可能)很容易解决的问题,但我自己无法解决。基本上我的reader.width和reader.height一直说未定义:/..其他一切都按预期工作 function handleFileSelec
我想像asp.net一样获取图像文件流并将它们传递到后台,但是每次我尝试触发onload事件时,它总是在编程通过后完成。 我尝试使用setTimeout来阻止它并让它处理并等待它成功,但它失败了。下面
我有两个类。首先是 TEXT 类:这里我读取了一个 6 行的文本文件。我只想逐行阅读,但这可行。但我想从第三行开始,并跳过最后一行,我只希望以 这是文本文件代码。 这是文件读取器的代码:
我仍在学习过程中,如果我有误解,请纠正我,但 FileReader 对象不应该返回文本文件的全部内容吗? 我这里有一段代码,我简单地尝试获取一个短.txt文件的内容,并使用system.out.pri
我收到错误“未处理的异常:java.io.FileNotFoundException,虽然我确定文件路径,但需要一些帮助 public static void main(String[] args)
我有一个我看不到的简单问题,希望另一双眼睛可以帮助我解决。除了我认为的文件阅读器之外,一切都运行良好。我应该让用户输入将其放入文件中,读取该文件并执行正确的操作。但由于某种原因,它只对用户输入的最后一
我尝试使用java.io.FileReader读取一些文本文件并将它们转换为字符串,但我发现结果编码错误并且根本不可读。 这是我的环境: Windows 2003,操作系统编码:CP1252 Java
在java中使用FileReader方法,使文件只读还是仍然需要声明 FileReader file = new FileReader(args[0]); BufferedReader buff
关闭。此题需要details or clarity 。目前不接受答案。 想要改进这个问题吗?通过 editing this post 添加详细信息并澄清问题. 已关闭10 年前。 Improve th
我是一名优秀的程序员,十分优秀!