利用数组储存表格数据

2024-04-11 07:44
文章标签 数据 数组 表格 储存

本文主要是介绍利用数组储存表格数据,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

原理以及普通数组储存表格信息

        在介绍数组的时候说过,数组能够用来储存任何同类型的数据,这里的意思就表明只要是同一个类型的数组据就可以储存到一个数组中。那么在表格中同一行的数据是否可以储存到同一个数组中呢?答案自然是可以,但是与之对应的疑惑便也产生了,比如一个学生类的表格中存储的信息是学生的姓名、年龄、籍贯、省份证号等等等等的信息,很明显他们的类型是完全不同的,那么怎么能将他们储存进一个数组中呢?

        在解决这个问题之前,先提出一个问题。在定义数组的时候我们采用的语法结构是

                数据类型 [ ] 数组名称 = new 数据类型 [ 数组长度] ;

那么这里的数据类型有多少种呢?估计会有人毫不犹豫地回答8种。因为java中有8中基本数据类型,因此很多人会这样回答。但是其实在java中还有字符串类型和引用类型,我们依然能创建与这两种数据类型对应的数组。因此确切来说这里的数据类型有10种。

        既然解决了数据类型的问题,那么这里再提出一个问题,那就是,这里的数据类型有多少种表达方式呢?如果回答10种,那么恭喜你又错了。因为有引用类型的存在,所以理论上来说这里的数据类型的表达可以有无数种方式,因为类属于引用类型,所以每一个类都可以写成数组的数据类型。比如如果定义了一个Person类,那么就可以定义数组 Person[ ] person = new Person[数组长度];而这里有一个很明显的问题,那几是类可以有无数个,因此数据类型的表达也就有了无数个。

        解决了以上问题,对于数组种能否储存表格中的数据这个问题也就迎刃而解了。首先之前说过,数组也是对象,其次new关键字能够用来创建对象。那么当我们用一个类的名称来定义数组时,是不是变成了这样的格式:

        类名 [ ] 数组名 = new 类名[ 数组长度];

可以发现,这个格式的右边与类中对象的创建非常相似,甚至在一定条件下可以说它就是创建了一个对象也无可厚非。而这个数组中储存的正好就是类的对象。比如我们以下面这个代码为例,当创建数据类型为Emp的数组emps时,因为数据类型为类名,所以创建数组中的元素时必须调用类的构造方法,创建这个类的对象,这时数组中的元素就是类Emp的对象。这样如果把每一个对象的信息都放入表格之中,那么这个数组中的信息不就是这个表格的信息吗。

package cn.luoyusanshu.array;
import java.util.Arrays;
/*** 使用javabean和一维数组储存表格信息*/
public class Test07 {public static void main(String[] args){Emp emp0 = new Emp(1001,"高小一",18,"程序员","2019-9-21");Emp emp1 = new Emp(1003,"高小二",19,"程序员","2019-8-21");Emp emp2 = new Emp(1005,"高小三",20,"程序员","2019-9-25");//Object[] emps = {emp0,emp1,emp2};Emp[] emps = new Emp[3];emps[0] = emp0;emps[1] = emp1;emps[2] = emp2;for (int i = 0; i < emps.length; i++) {System.out.println(emps[i].getId()+"\t"+emps[i].getAge()+"\t"+emps[i].getName());}for (int i = 0; i < emps.length; i++) {System.out.println(emps[i]);}}
}
class Emp{private int id;private String name;private int age;private String job;private String hiredate;public Emp(){}public Emp(int id, String name, int age, String job, String hiredate) {this.id = id;this.name = name;this.age = age;this.job = job;this.hiredate = hiredate;}public int getId() {return id;}public void setId(int id) {this.id = id;}@Overridepublic String toString() {return getId()+"\t"+getName()+"\t"+getAge()+"\t"+getJob()+"\t"+getHiredate();}public String getName() {return name;}public void setName(String name) {this.name = name;}public int getAge() {return age;}public void setAge(int age) {this.age = age;}public String getJob() {return job;}public void setJob(String job) {this.job = job;}public String getHiredate() {return hiredate;}public void setHiredate(String hiredate) {this.hiredate = hiredate;}
}

Object数组储存表格信息 

        由此我们已经知道了普通数组可以用来储存表格的信息,但是这却也带来了一个麻烦,那就是每一次要储存一个表格的信息都要重新定义一个类,这样显得过于麻烦且没有必要。为了解决这样一个问题Object数组便出现了,我们都知道Object类是所有类的父类,所以如果使用Object类作为数组的数据类型就意味着它可以直接对表格数据进行存储。比如在下面的这个代码中,a1[0]数组便能够储存这些看似为不同类型的数据,当然这只是表面上的,其实这些数据都是同一个类型——对象。这里要注意的是java中的基本数据类型并不属于对象,但在使用中当需要这些数据类型变为对象的时候大多数情况下系统会自动对其进行装箱操作,从而将其转化为对象。

package cn.luoyusanshu.array;
import java.util.Arrays;
public class Test06 {public static void main(String[] args) {Object[][] a1 = new Object[3][];a1[0]=new Object[]{1001,"高小一",18,"讲师","2002-90-17"};a1[1]=new Object[]{1001,"高小二",18,"讲师","2002-90-19"};a1[1]=new Object[]{1001,"高小三",18,"讲师","2002-90-27"};System.out.println(a1[0]);System.out.println(Arrays.toString(a1[0]));Object[] emp0 = {1001,"高小一",18,"讲师","2002-90-17"};Object[] emp1 = {1001,"高小二",18,"讲师","2002-90-16"};Object[] emp2 = {1001,"高小三",18,"讲师","2002-90-28"};Object[][] emp = new Object[3][];emp[0] = emp0;emp[1] = emp1;emp[2] = emp2;System.out.println(Arrays.toString(emp[0]));System.out.println(Arrays.toString(emp[1]));System.out.println(Arrays.toString(emp[2]));System.out.println("____________________________");for (int i = 0; i < emp.length; i++) {System.out.println(Arrays.toString(emp[i]));}System.out.println("_______________________________");for (int i = 0; i <emp.length ; i++) {for (int j = 0; j < emp[i].length; j++) {System.out.print(emp[i][j]+"\t");}System.out.println();}}
}

这篇关于利用数组储存表格数据的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/893481

相关文章

Python获取中国节假日数据记录入JSON文件

《Python获取中国节假日数据记录入JSON文件》项目系统内置的日历应用为了提升用户体验,特别设置了在调休日期显示“休”的UI图标功能,那么问题是这些调休数据从哪里来呢?我尝试一种更为智能的方法:P... 目录节假日数据获取存入jsON文件节假日数据读取封装完整代码项目系统内置的日历应用为了提升用户体验,

Java利用JSONPath操作JSON数据的技术指南

《Java利用JSONPath操作JSON数据的技术指南》JSONPath是一种强大的工具,用于查询和操作JSON数据,类似于SQL的语法,它为处理复杂的JSON数据结构提供了简单且高效... 目录1、简述2、什么是 jsONPath?3、Java 示例3.1 基本查询3.2 过滤查询3.3 递归搜索3.4

MySQL大表数据的分区与分库分表的实现

《MySQL大表数据的分区与分库分表的实现》数据库的分区和分库分表是两种常用的技术方案,本文主要介绍了MySQL大表数据的分区与分库分表的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有... 目录1. mysql大表数据的分区1.1 什么是分区?1.2 分区的类型1.3 分区的优点1.4 分

Mysql删除几亿条数据表中的部分数据的方法实现

《Mysql删除几亿条数据表中的部分数据的方法实现》在MySQL中删除一个大表中的数据时,需要特别注意操作的性能和对系统的影响,本文主要介绍了Mysql删除几亿条数据表中的部分数据的方法实现,具有一定... 目录1、需求2、方案1. 使用 DELETE 语句分批删除2. 使用 INPLACE ALTER T

Python Dash框架在数据可视化仪表板中的应用与实践记录

《PythonDash框架在数据可视化仪表板中的应用与实践记录》Python的PlotlyDash库提供了一种简便且强大的方式来构建和展示互动式数据仪表板,本篇文章将深入探讨如何使用Dash设计一... 目录python Dash框架在数据可视化仪表板中的应用与实践1. 什么是Plotly Dash?1.1

Redis 中的热点键和数据倾斜示例详解

《Redis中的热点键和数据倾斜示例详解》热点键是指在Redis中被频繁访问的特定键,这些键由于其高访问频率,可能导致Redis服务器的性能问题,尤其是在高并发场景下,本文给大家介绍Redis中的热... 目录Redis 中的热点键和数据倾斜热点键(Hot Key)定义特点应对策略示例数据倾斜(Data S

利用Python开发Markdown表格结构转换为Excel工具

《利用Python开发Markdown表格结构转换为Excel工具》在数据管理和文档编写过程中,我们经常使用Markdown来记录表格数据,但它没有Excel使用方便,所以本文将使用Python编写一... 目录1.完整代码2. 项目概述3. 代码解析3.1 依赖库3.2 GUI 设计3.3 解析 Mark

Python实现将MySQL中所有表的数据都导出为CSV文件并压缩

《Python实现将MySQL中所有表的数据都导出为CSV文件并压缩》这篇文章主要为大家详细介绍了如何使用Python将MySQL数据库中所有表的数据都导出为CSV文件到一个目录,并压缩为zip文件到... python将mysql数据库中所有表的数据都导出为CSV文件到一个目录,并压缩为zip文件到另一个

SpringBoot整合jasypt实现重要数据加密

《SpringBoot整合jasypt实现重要数据加密》Jasypt是一个专注于简化Java加密操作的开源工具,:本文主要介绍详细介绍了如何使用jasypt实现重要数据加密,感兴趣的小伙伴可... 目录jasypt简介 jasypt的优点SpringBoot使用jasypt创建mapper接口配置文件加密

使用Python高效获取网络数据的操作指南

《使用Python高效获取网络数据的操作指南》网络爬虫是一种自动化程序,用于访问和提取网站上的数据,Python是进行网络爬虫开发的理想语言,拥有丰富的库和工具,使得编写和维护爬虫变得简单高效,本文将... 目录网络爬虫的基本概念常用库介绍安装库Requests和BeautifulSoup爬虫开发发送请求解