有一个文件内容是这样的 header1| header2| header3| header4|…. A1|A2|A3|A4|… B1|B2|B3|B4|… 写一个完整的Java program,读取文件,然后把header和对应的body中存储到Map中

时间: 2023-08-27 12:14:05 浏览: 161
PDF

matlab中如何读取文本文件.pdf

下面是一个完整的 Java 程序,读取文件并将 header 和对应的 body 存储到 Map 中的示例: ```java import java.io.BufferedReader; import java.io.FileReader; import java.io.IOException; import java.util.HashMap;import java.util.Map; public class FileToMap { public static void main(String[] args) { String filePath = "path/to/your/file.txt"; // 替换为你的文件路径 Map<String, String[]> map = new HashMap<>(); try (BufferedReader reader = new BufferedReader(new FileReader(filePath))) { String line; boolean isFirstLine = true; String[] headers = null; while ((line = reader.readLine()) != null) { if (isFirstLine) { headers = line.split("\\|"); isFirstLine = false; } else { String[] body = line.split("\\|"); for (int i = 0; i < headers.length; i++) { map.put(headers[i], body[i]); } } } } catch (IOException e) { e.printStackTrace(); } // 打印 Map 中的数据 for (Map.Entry<String, String[]> entry : map.entrySet()) { String header = entry.getKey(); String[] body = entry.getValue(); System.out.println(header + ": " + String.join(", ", body)); } } } ``` 请将代码中的 `filePath` 替换为你实际的文件路径。这段代码使用 `BufferedReader` 逐行读取文件内容,并根据第一行的 header 创建一个数组来存储每一列的数据。接下来,对于每一行的 body 数据,将其与对应的 header 放入 Map 中。 最后,遍历 Map 并打印出每个 header 和对应的 body 数据。你可以根据需要进行修改和扩展。
阅读全文

相关推荐

import numpy as np import pylab as pl import pandas as pd import numpy as np from scipy.optimize import leastsq X2=[] X3=[] X4=[] X5=[] X6=[] X7=[] X1=[i for i in range(1,24) for j in range(128)] df=pd.read_excel('C:/Users/86147/OneDrive/文档/777.xlsx',header=0,usecols=(3,)) X2=df.values.tolist() x2=[] for i in X2: if X2.index(i)>2927: #两个单元楼的分隔数 x2.append(i) df=pd.read_excel('C:/Users/86147/OneDrive/文档/777.xlsx',header=0,usecols=(4,)) X3=df.values.tolist() x3=[] for i in X3: if X3.index(i)>2927: x3.append(i) df=pd.read_excel('C:/Users/86147/OneDrive/文档/777.xlsx',header=0,usecols=(5,)) X4=df.values.tolist() x4=[] for i in X4: if X4.index(i)>2927: x4.append(i) df=pd.read_excel('C:/Users/86147/OneDrive/文档/777.xlsx',header=0,usecols=(6,)) X5=df.values.tolist() x5=[] for i in X5: if X5.index(i)>2927: x5.append(i) df=pd.read_excel('C:/Users/86147/OneDrive/文档/777.xlsx',header=0,usecols=(7,)) X6=df.values.tolist() x6=[] for i in X6: if X6.index(i)>2927: x6.append(i) df=pd.read_excel('C:/Users/86147/OneDrive/文档/777.xlsx',header=0,usecols=(8,)) X7=df.values.tolist() x7=[] for i in X7: if X7.index(i)>2927: x7.append(i) df=pd.read_excel('C:/Users/86147/OneDrive/文档/66666.xlsx',header=0,usecols=(1,)) mylist1=df.values.tolist() room=[] for i in mylist1: room.append(i[0]) df=pd.read_excel('C:/Users/86147/OneDrive/文档/66666.xlsx',header=0,usecols=(2,)) mylist1=df.values.tolist() tomp=[] for i in mylist1: tomp.append(i[0]) Y=[] for i in range(1,185): room_tomp=zip(room,tomp) ls=[] for k,v in room_tomp: if k<=92: ls.append(v) for w in range(32): Y.append(ls[w])#通过循环y对应列表共有2944个数据 q=X1[:2922] w=X2[:2922] e=X3[:2922] r=X4[:2922] t=X5[:2922] p=X6[:2922] u=X7[:2922] x=np.column_stack((q,w,e,r,t,p,u)).T y=np.array(Y[:2922]).T # 定义待拟合的函数 def func(params, x, y): a1, a2, a3, a4, a5, a6, a7, b = paramsreturn a1 * x[:,0] + a2 * x[:,1] + a3 * x[:,2] + a4 * x[:,3] + a5 * x[:,4] + a6 * x[:,5] + a7 * x[:,6] + b - y # 求解参数 params0 = np.ones(8) # 初始参数 params, flag = leastsq(func, params0, args=(x, y)) # 求解参数 # 输出结果 print(f"a1: {params[0]}, a2: {params[1]}, a3: {params[2]}, a4: {params[3]}, a5: {params[4]}, a6: {params[5]}, a7: {params[6]}, b: {params[7]}")修改这个代码要求其可以准确的求出参数

最新推荐

recommend-type

nginx配置教程之add_header的坑详解

例如,以下配置将添加一个名为 `X-Custom-Header` 的头部,其值为 `Value`: ```nginx location / { add_header X-Custom-Header "Value"; } ``` **陷阱1:只添加不覆盖** `add_header` 不会覆盖已经存在的同名...
recommend-type

Element PageHeader页头的使用方法

PageHeader 是 Element UI 中的一个组件,主要用于创建页面头部,它提供了导航、返回、标题显示等功能,有助于提升用户体验和应用的视觉一致性。 在 Element UI 中,PageHeader 组件通常用于展示页面的主要标题,...
recommend-type

Golang 发送http请求时设置header的实现

至此,我们就成功地发送了一个带有自定义Header的HTTP请求。若要处理响应体,可以使用`ioutil.ReadAll`将其读入一个字节数组,然后转换成字符串或JSON进行解析。 ```go body, err := ioutil.ReadAll(response.Body)...
recommend-type

浅析HTML5中header标签的用法

HTML5中的&lt;header&gt;标签是一个非常重要的语义化标签,它为网页内容提供了结构化的框架,帮助用户和搜索引擎更好地理解和解析页面布局。与标签不同,主要用于存放元数据,如标题、字符集设置、样式表链接等,而&lt;header...
recommend-type

解决方案 ‘Access-Control-Allow-Origin’ header in the response must not be the wildcard ‘*’

标题 "解决方案 ‘Access-Control-Allow-Origin’ header in the response must not be the wildcard ‘*’" 提到的是一个在Web开发中常见的跨域问题。`Access-Control-Allow-Origin` 是一个用于控制资源跨域访问的...
recommend-type

创建个性化的Discord聊天机器人教程

资源摘要信息:"discord_bot:用discord.py制作的Discord聊天机器人" Discord是一个基于文本、语音和视频的交流平台,广泛用于社区、团队和游戏玩家之间的通信。Discord的API允许开发者创建第三方应用程序,如聊天机器人(bot),来增强平台的功能和用户体验。在本资源中,我们将探讨如何使用Python库discord.py来创建一个Discord聊天机器人。 1. 使用discord.py创建机器人: discord.py是一个流行的Python库,用于编写Discord机器人。这个库提供了一系列的接口,允许开发者创建可以响应消息、管理服务器、与用户交互等功能的机器人。使用pip命令安装discord.py库,开发者可以开始创建和自定义他们的机器人。 2. discord.py新旧版本问题: 开发者在创建机器人时应确保他们使用的是与Discord API兼容的discord.py版本。本资源提到的机器人是基于discord.py的新版本,如果开发者有使用旧版本的需求,资源描述中指出需要查看相应的文档或指南。 3. 命令清单: 机器人通常会响应一系列命令,以提供特定的服务或功能。资源中提到了一些默认前缀“努宗”的命令,例如:help命令用于显示所有公开命令的列表;:epvpis 或 :epvp命令用于进行某种搜索。 4. 自定义和自托管机器人: 本资源提到的机器人是自托管的,并且设计为高度可定制。这意味着开发者可以完全控制机器人的运行环境、扩展其功能,并将其部署在他们选择的服务器上。 5. 关键词标签: 文档的标签包括"docker", "cog", "discord-bot", "discord-py", 和 "python-bot"。这些标签指示了与本资源相关的技术领域和工具。例如,Docker可用于容器化应用程序,使得机器人可以在任何支持Docker的操作系统上运行,从而提高开发、测试和部署的一致性。标签"python-bot"强调了使用Python语言创建Discord机器人的重要性,而"cog"可能是指在某些机器人框架中用作模块化的代码单元。 6. 文件名称列表: 资源中的"discord_bot-master"表明这是从一个源代码仓库获取的,可能是GitHub上公开的项目。"master"通常是指项目的主分支或主要版本。 总结: 通过本资源,开发者可以学习到如何利用Python和discord.py库来创建功能丰富的Discord聊天机器人。资源涵盖了安装库、创建命令响应、自托管机器人、以及如何根据新旧版本API进行适配等内容。这不仅对初学者入门,对有经验的开发者进一步学习和提升技能也是有价值的。通过理解这些知识点,开发者可以构建出适合他们需要的自定义机器人,进而为Discord社区提供附加价值。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

【Eclipse软件终极指南】:油藏数值模拟新手到专家的必经之路

![【Eclipse软件终极指南】:油藏数值模拟新手到专家的必经之路](https://ucc.alicdn.com/pic/developer-ecology/ajpxbl4ljzs5k_9cbe41a1e6e34e6a87c7f49567bdef32.jpeg?x-oss-process=image/resize,s_500,m_lfit) 参考资源链接:[油藏数值模拟基础:ECLIPSE软件详解](https://wenku.csdn.net/doc/2v49ka4j2q?spm=1055.2635.3001.10343) # 1. Eclipse软件概述及应用领域 ## 1.1 软
recommend-type

mvn 命令打包时 指定jdk 的版本、和环境变量

当使用`mvn`命令打包时,有时确实需要指定特定版本的Java Development Kit (JDK) 或设置环境变量,特别是当你的项目依赖于某个特定版本或者你需要在不同的JDK环境下进行构建。以下是两个关键的部分: 1. **指定JDK版本**: 如果你想强制`mvn`使用特定的JDK版本,可以在`.mvn/wrapper/maven-wrapper.properties`文件中添加`maven.jdk.home`属性,然后更新其值指向你想要使用的JDK安装路径。例如: ``` maven.jdk.home=/path/to/jdk-version ```
recommend-type

RequireJS实现单页应用延迟加载模块示例教程

资源摘要信息:"example-onepage-lazy-load是一个基于RequireJS的单页或多页应用程序示例项目,该项目展示了如何实现模块的延迟加载。延迟加载是一种编程技术,旨在在需要时才加载应用程序的某些部分,从而提高应用程序的初始加载速度和性能。RequireJS是一个JavaScript文件和模块加载器,它能够管理JavaScript文件的依赖关系,并且通过异步加载模块,可以进一步优化页面加载性能。 在这个示例项目中,开发者可以了解到如何使用RequireJS来实现模块的懒加载。这涉及到了几个关键点: 1. 将应用程序分为多个模块,这些模块在不立即需要时不会被加载。 2. 使用RequireJS的配置来定义模块之间的依赖关系,以及如何异步加载这些依赖。 3. 通过合并JavaScript文件,减少页面请求的数量,这有助于降低服务器负载并减少延迟。 4. 利用RequireJS的优化器(r.js)来拆分构建目标,生成更小的文件,这有助于加速应用的启动时间。 RequireJS的工作原理基于模块化编程的概念,它允许开发者将JavaScript代码拆分成逻辑块,每一个块都包含特定的功能。这些模块可以被定义为依赖其他模块,RequireJS则负责按照正确的顺序加载这些模块。它提供了一个全局的`require()`函数,开发者可以通过这个函数来声明他们的代码依赖和加载其他模块。 这个示例项目也强调了模块化和代码组织的重要性。项目的布局设计得非常简单明了,通常包含以下几个部分: - `build`目录:存放RequireJS优化器的配置文件(如option.js),用于指定如何打包和优化模块。 - `www`目录:包含所有静态资源,比如HTML页面、样式表和图片等。这个目录的结构旨在让静态资源独立于应用逻辑,便于部署和维护。 在项目中使用RequireJS可以带来几个显著的好处: - 模块化能够改善代码的组织和维护性。 - 异步加载可以减少页面加载时间,提升用户体验。 - 通过合并和压缩文件,可以减少HTTP请求的数量,加快页面渲染速度。 关于`r.js`,它是RequireJS项目中的一个命令行工具,用于自动化模块的打包和优化过程。它能够读取RequireJS的配置文件,自动处理依赖关系,合并模块,并输出优化后的文件。这对于生产环境中的代码部署尤其有用,因为它能够将多个JavaScript文件压缩成一个或几个较小的文件,从而减少网络传输的负担。 总结来说,这个示例项目演示了如何使用RequireJS来实现延迟加载和模块化,这对于优化现代Web应用的性能和管理大型代码库至关重要。开发者可以借鉴这个项目来提高自己的JavaScript应用性能,以及更好地理解和应用RequireJS的特性和最佳实践。"