各种读取resources目录下文件的方法(图文解释)

本文详细介绍了在Java Web项目中通过八种方式获取resources目录下文件的路径,包括使用getClassLoader、getResource、getPath和getFile方法,以及System.getProperty('user.dir')和ClassPathResource类。并展示了如何结合实际操作展示文件内容。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

引言

  我们写使用java写web项目时,有时需要将某些文件存放到resources目录下,之后我们需要在程序中去获取文件。此时就有一个重要的事情:如何获取文件的路径?
  下面我将给出八种获取resources的方式。

注意:有的可以在web项目中使用,有的则不可以在web项目中使用。

读取展示文件的工具方法

首先给出读取展示 文件的代码块:

/**
     * 需要有明确路径,因为需要输出显示,所以最好是文本文档:“.txt”、“.html”、“.js”等
     * @param fileInPath
     * @throws IOException
     */
    public static void getFileContent(Object fileInPath) throws IOException {
        BufferedReader br = null;
        if (fileInPath == null) {
            return;
        }
        if (fileInPath instanceof String) {
            //如果是字符串路径
            br = new BufferedReader(new FileReader(new File((String) fileInPath)));
        } else if (fileInPath instanceof InputStream) {
            //如果是输入流
            br = new BufferedReader(new InputStreamReader((InputStream) fileInPath));
        }
        String line;
        while ((line = br.readLine()) != null) {
            System.out.println(line);
        }
        br.close();
    }

先获取路径再去获取文件

准备:getFile() getPath()须知

  我们使用:

this.getClass().getClassLoader().getResource("").[getPath()/getFile()];

这个命令去获取resource的路径,下面我打断点,可以看到resource的内容,里面有file,path。
在这里插入图片描述
如果是文件路径的话getFile和getPath效果是一样的,如果是URL路径的话getFile是带有参数的路径。
例如:
在这里插入图片描述

getResource(“”).getPath()获取resource路径

/**
     * 读取resources下的文件,getResource("")然后拼接
     * @param fileName
     * @throws IOException
     */
    public void function1(String fileName)throws IOException{
        String path = this.getClass().getClassLoader().getResource("").getPath();
        path = URLDecoder.decode(path,"UTF-8");
        System.out.println(path);
        String filePath = path + fileName;
        System.out.println(filePath);
        getFileContent(filePath);
    }

getResource(fileName).getPath()直接获取完整路径

/**
     * getResource(fileName)直接获取完整路径
     * @param fileName
     * @throws IOException
     */
    public void function2(String fileName)throws IOException{
        String path = this.getClass().getClassLoader().getResource(fileName).getPath();
        System.out.println(path);
        String filePath = URLDecoder.decode(path,"UTF-8");
        System.out.println(filePath);
        getFileContent(filePath);
    }

getResource(fileName).getFile()获取完整路径

/**
     * getFile()
     * @param fileName
     * @throws IOException
     */
    public void function3(String fileName)throws IOException{
        String path = this.getClass().getClassLoader().getResource(fileName).getFile();
        System.out.println(path);
        String filePath = URLDecoder.decode(path,"UTF-8");
        System.out.println(filePath);
        getFileContent(filePath);
    }

System.getProperty(“user.dir”)(不能在web应用使用)

/**
     * user.dir默认会定位到你的工程根目录,但是web项目不行如果是web项目会定位到tomcat的bin目录
     * @param fileName
     * @throws IOException
     */
    public void function7(String fileName)throws IOException{
        String rootPath = System.getProperty("user.dir");
        String filePath = rootPath+"/src/main/resources/"+fileName;
        getFileContent(filePath);
    }

getCanonicalPath();getAbsolutePath()

/**
     * 不能在web应用中使用。
     * @param fileName
     * @throws IOException
     */
    public void function8(String fileName)throws IOException{
        File directory = new File("");
        //规范路径:getCanonicalPath()方法返回绝对路径
        String rootCanonicalPath = directory.getCanonicalPath();
        //绝对路径:getAbsolutePath()方法返回文件的绝对路径,如果创建的时候使用的绝对路径返回绝对路径,创建的时候使用的相对路径,返回相对路径
        String rootAbsolutePath = directory.getAbsolutePath();
        System.out.println(rootCanonicalPath);
        System.out.println(rootAbsolutePath);
        String filePath = rootCanonicalPath+"/src/main/resources/"+fileName;
        getFileContent(filePath);
    }

直接去获取流

  现在主流的部署方式是将项目打成jar包部署。而在jar包中是没有路径的,因为系统会认为jar包是个文件。所以我们就要通过流的方式去获取文件。

getResourceAsStream获取流

/**
     * 直接获取流数据
     * @param fileName
     * @throws IOException
     */
    public void function(String fileName)throws IOException{
        InputStream in = this.getClass().getClassLoader().getResourceAsStream(fileName);
        getFileContent(in);
    }

不使用getClassLoader获取流

/**
     * 不使用getClassLoader,直接获取resources下的文件。需要前面添加”/“
     * @param fileName
     * @throws IOException
     */
    public void function(String fileName)throws IOException{
        InputStream in = this.getClass().getResourceAsStream("/"+fileName);
        getFileContent(in);
    }

ClassPathResource类获取流


    /**
     * 通过ClassPathResource类获取,建议SpringBoot中使用
     * @param fileName
     * @throws IOException
     */
    public void function6(String fileName)throws IOException{
        ClassPathResource classPathResource = new ClassPathResource(fileName);
        InputStream in = classPathResource.getInputStream();
        getFileContent(in);
    }

<think>好的,用户的问题是在Unity中读取文档并保留格式和布局显示在UI上。首先,我需要确定用户可能需要的文档格式,比如txt、HTML、富文本、PDF或Word等。不同的格式处理方式不同,所以得分别考虑。 接下来,处理纯文本的情况。Unity的Text组件支持基本的换行符和空格,但对于更复杂的格式可能需要使用富文本标签。比如使用<b>加粗</b>这样的标签。同时,用户可能需要自动换行功能,这可以通过Horizontal Overflow设置为Wrap来实现。 然后是富文本的处理。Unity的Text组件支持部分HTML标签,但可能需要使用第三方库比如HtmlAgilityPack来解析更复杂的HTML内容。不过用户提到要保持原格式,可能需要将HTML转换为Unity支持的富文本格式,或者使用WebView插件在UI中嵌入浏览器组件来显示完整的HTML内容。 对于PDF或Word文档,Unity原生支持有限,可能需要使用插件。比如Aspose.Words for .NET可以解析Word文档并提取内容,再结合富文本显示。PDF的话,可能需要使用PDF解析库,如PdfPig,提取文本和格式信息,再在UI中重新排版。不过这样可能会比较复杂,特别是保持布局一致。 另外,用户可能需要考虑使用TextMesh Pro来增强文本显示效果,因为它支持更丰富的文本格式和布局选项。同时,布局组件如Vertical Layout Group和Content Size Fitter可以帮助自动调整UI元素的尺寸和位置,保持文档结构。 如果用户需要精确的格式还原,比如表格或复杂排版,可能需要将文档转换为图片,在UI中显示图片。但这会增加存储和内存开销。或者使用第三方插件如Embedded Browser来渲染HTML内容,这样可以直接在Unity中显示网页形式的文档,保持原有布局。 还要考虑文档的动态加载和性能问题。比如使用Resources.Load或AssetBundle加载文档资源,异步读取避免卡顿。对于大文档,分页显示可能更合适。 最后,可能需要根据用户的具体需求推荐合适的解决方案组合,比如使用Aspose解析Word,用TextMesh Pro显示富文本,配合布局组件调整UI。同时提供代码示例,比如读取文本文件并使用Text组件显示,或者解析HTML并转换为富文本标签。 需要验证引用中的信息是否相关,比如引用[1]提到Unity样式表,可能和UI布局有关;引用[3][4]讨论UI控制和显示隐藏,可能涉及UI组件的动态管理。但用户的主要问题是如何读取并显示文档格式,所以重点在解析和渲染部分。可能需要建议用户查看Aspose的文档(引用[2])来处理Word文件,或者使用WebView插件实现HTML渲染。</think>在Unity中实现文档读取并保留格式显示,可通过以下分步方案实现: ### 一、基础文本处理 1. **纯文本读取**: ```csharp // 读取txt文件 TextAsset textAsset = Resources.Load<TextAsset>("document"); GetComponent<Text>().text = textAsset.text; ``` 通过$HorizontalOverflow$属性控制换行,设置$Text$组件的`Horizontal Overflow`为Wrap[^3] 2. **富文本支持**: ```csharp // 启用富文本标记 GetComponent<Text>().supportRichText = true; ``` 支持使用$<b>Bold</b>$, $<i>Italic</i>$, $<size=20>Size</size>$等标签[^4] ### 二、高级格式处理 1. **HTML解析**: ```csharp // 使用HtmlAgilityPack解析 var doc = new HtmlDocument(); doc.LoadHtml(htmlContent); // 转换为Unity富文本格式 string richText = ConvertHtmlToUnityTags(doc); ``` 需要自行实现HTML标签到Unity富文本的转换逻辑[^1] 2. **PDF/Word处理**: ```csharp // 使用Aspose.Words读取DOCX Document doc = new Document("document.docx"); string text = doc.GetText(); // 提取格式信息 foreach (Paragraph para in doc.GetChildNodes(NodeType.Paragraph, true)) { // 处理段落样式 } ``` 需导入Aspose.Words插件[^2] ### 三、UI布局方案 1. **动态布局组件**: ```csharp // 添加自动布局组件 gameObject.AddComponent<VerticalLayoutGroup>(); gameObject.AddComponent<ContentSizeFitter>().verticalFit = ContentSizeFitter.FitMode.PreferredSize; ``` 可自动调整内容区域大小[^4] 2. **图文混排**: ```csharp // 创建混合布局 foreach (var element in documentElements) { if(element is TextBlock) CreateText(element); if(element is Image) CreateImage(element); } ``` 需配合$GridLayoutGroup$或自定义布局脚本实现[^3] ### 四、专业解决方案 1. **WebView插件集成**: ```csharp // 使用UnityWebBrowser插件 var browser = gameObject.AddComponent<UnityWebBrowser>(); browser.LoadHtml(htmlContent); ``` 可完整保留原始网页布局[^1] 2. **文档转位图**: ```csharp // 使用Ghostscript转换PDF为图片 Texture2D docImage = ConvertPDFToTexture("document.pdf"); GetComponent<Image>().sprite = Sprite.Create(docImage, new Rect(0,0,1024,768), Vector2.zero); ``` 适合需要精确还原版式的场景
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值