- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在编写一些脚本来原子化我几乎每天都需要执行的手动功能。
我的第一个问题是从路径和 zip 文件名构建一个字符串。第二个问题是循环遍历 zip 文件名(路径+zip 文件名)。
这是包含多个 zip 文件的目录路径:/Users/John.Smith/Desktop/Test_script/
以下是众多 zip 文件之一的名称:CRM_CI_20161016_000001_50661561.zip
最后,我需要循环遍历每个 zip 文件名称中的目录和子字符串(数字 50661561
)以便对其进行操作。
有人可以给我建议吗?
这是我在下面给出的代码,用于仅操作一个 zip 文件:
import java.io.File;
import java.io.IOException;
import java.nio.file.Files;
import java.nio.file.Path;
import java.nio.file.Paths;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.ParserConfigurationException;
import javax.xml.transform.Transformer;
import javax.xml.transform.TransformerException;
import javax.xml.transform.TransformerFactory;
import javax.xml.transform.dom.DOMSource;
import javax.xml.transform.stream.StreamResult;
import org.w3c.dom.Document;
import org.w3c.dom.Node;
import org.xml.sax.SAXException;
public class UnzipUtilityTest {
public static void main(String[] args) {
// unzip file
String zipFilePath = "/Users/John.Smith/Desktop/Test_script/CRM_CI_20161016_000001_50661561.zip";
String destDirectory = "/Users/John.Smith/Desktop/Test_script/test";
UnzipUtility unzipper = new UnzipUtility();
try {
unzipper.unzip(zipFilePath, destDirectory);
} catch (Exception ex) {
System.out.println("ERROR:Unzip did not work");
}
// read provider id
String old_prov_id = zipFilePath.substring(66, 74);
System.out.println("Old provider ID :"+old_prov_id );
// add +1 to provider ID
int new_provider_ID = Integer.parseInt(old_prov_id);
new_provider_ID++;
System.out.println("New provider ID :"+new_provider_ID );
// convert provider-id INT into String
String str_provider_id = Integer.toString(new_provider_ID);
System.out.println("New String provider ID :"+str_provider_id );
// concatenate two String into one
StringBuilder bufferPDF = new StringBuilder()
.append(new_provider_ID).append(".pdf");
System.out.println(bufferPDF.toString());
StringBuilder bufferXML = new StringBuilder()
.append(new_provider_ID).append(".xml");
System.out.println(bufferXML.toString());
// convert names of XML and PDF
Path sourcePDF = Paths.get("/Users/John.Smith/Desktop/Test_script/test/50661561.pdf");
try {
Files.move(sourcePDF, sourcePDF.resolveSibling(bufferPDF.toString()));
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
Path sourceXML = Paths.get("/Users/John.Smith/Desktop/Test_script/test/50661561.xml");
try {
Files.move(sourceXML, sourceXML.resolveSibling(bufferXML.toString()));
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
// change provider-id and filename in xml file
try {
String filepath = "/Users/John.Smith/Desktop/Test_script/test/50661562.xml";
DocumentBuilderFactory docFactory = DocumentBuilderFactory.newInstance();
DocumentBuilder docBuilder = docFactory.newDocumentBuilder();
Document doc = docBuilder.parse(filepath);
// Get the root element provider-id
Node provider = doc.getElementsByTagName("provider-id").item(0);
provider.setTextContent(str_provider_id);
// Get the root element filename
Node filename = doc.getElementsByTagName("filename").item(0);
filename.setTextContent(str_provider_id);
// write the content into xml file
TransformerFactory transformerFactory = TransformerFactory.newInstance();
Transformer transformer = transformerFactory.newTransformer();
DOMSource source = new DOMSource(doc);
StreamResult result = new StreamResult(new File(filepath));
transformer.transform(source, result);
System.out.println("Done");
} catch (ParserConfigurationException pce) {
pce.printStackTrace();
} catch (TransformerException tfe) {
tfe.printStackTrace();
} catch (IOException ioe) {
ioe.printStackTrace();
} catch (SAXException sae) {
sae.printStackTrace();
}
}
}
最佳答案
我的处理方式有点不同:
示例:
//you could probably make this nicer
String fileNamePattern = "CRM_CI_\\d{8}_\\d{6}_\\d{8}\\.zip";
String oldProvIdPattern = "CRM_CI_\\d{8}_\\d{6}_(\\d{8})\\.zip";
String pathToZips = "/Users/John.Smith/Desktop/Test_script/"
String destinationPath = "/Users/John.Smith/Desktop/Test_script/test";
File dir = new File(".");
FileFilter fileFilter = new RegexFileFilter(fileNamePattern);
File[] files = pathToZips.listFiles(fileFilter);
for (File file : files) {
//Handle each zip here
String zipPath = file.getAbsolutePath();
try {
unzipper.unzip(zipPath, destinationPath);
} catch (Exception ex) {
System.out.println("ERROR:Unzip did not work");
}
Pattern pattern = Pattern.compile(oldProvIdPattern);
Matcher matcher = pattern.matcher(file.getName());
if (matcher.find()){
String old_prov_id = matcher.group(1);
System.out.println("Old provider ID :"+old_prov_id );
// add +1 to provider ID
int new_provider_ID = Integer.parseInt(old_prov_id);
new_provider_ID++;
System.out.println("New provider ID :"+new_provider_ID );
// convert provider-id INT into String
String str_provider_id = Integer.toString(new_provider_ID);
System.out.println("New String provider ID :"+str_provider_id );
// concatenate two String into one
StringBuilder bufferPDF = new StringBuilder()
.append(new_provider_ID).append(".pdf");
System.out.println(bufferPDF.toString());
StringBuilder bufferXML = new StringBuilder()
.append(new_provider_ID).append(".xml");
System.out.println(bufferXML.toString());
// convert names of XML and PDF
Path sourcePDF = Paths.get("/Users/John.Smith/Desktop/Test_script/test/" + old_prov_id + ".pdf");
try {
Files.move(sourcePDF, sourcePDF.resolveSibling(bufferPDF.toString()));
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
Path sourceXML = Paths.get("/Users/John.Smith/Desktop/Test_script/test/" + old_prov_id + ".xml");
try {
Files.move(sourceXML, sourceXML.resolveSibling(bufferXML.toString()));
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
// change provider-id and filename in xml file
try {
String filepath = "/Users/John.Smith/Desktop/Test_script/test/" + old_prov_id + ".xml";
DocumentBuilderFactory docFactory = DocumentBuilderFactory.newInstance();
DocumentBuilder docBuilder = docFactory.newDocumentBuilder();
Document doc = docBuilder.parse(filepath);
// Get the root element provider-id
Node provider = doc.getElementsByTagName("provider-id").item(0);
provider.setTextContent(str_provider_id);
// Get the root element filename
Node filename = doc.getElementsByTagName("filename").item(0);
filename.setTextContent(str_provider_id);
// write the content into xml file
TransformerFactory transformerFactory = TransformerFactory.newInstance();
Transformer transformer = transformerFactory.newTransformer();
DOMSource source = new DOMSource(doc);
StreamResult result = new StreamResult(new File(filepath));
transformer.transform(source, result);
System.out.println("Done");
} catch (ParserConfigurationException pce) {
pce.printStackTrace();
} catch (TransformerException tfe) {
tfe.printStackTrace();
} catch (IOException ioe) {
ioe.printStackTrace();
} catch (SAXException sae) {
sae.printStackTrace();
}
}
}
关于java - 如何连接从路径到目录的字符串和目录中的多个 zip 文件名?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40212771/
我正在为我的程序编写安装脚本,它应该在 Linux/Unix 操作系统上运行。以下文件的默认目录是什么: 可执行文件(程序)。程序应通过从命令行键入其名称来执行。 共享库。 第三方共享库(程序未开源,
我有一堆用户、组和应用程序注册,我的 MVC 应用程序使用 AAD 数据进行身份验证和授权。是否可以将 Azure Active Directory 从一个租户(目录)迁移到另一个租户(目录)?如果可
查看 cljsbuild 文档 https://github.com/emezeske/lein-cljsbuild :cljsbuild { :builds [{ ; The
忽略已经版本控制的文件 如果你不小心添加了一些应该被忽略的文件,你如何将它们从版本控制中去除而不会丢失它们?或许你有自己的IDE配置文件,不是项目的一部分,但将会花费很多时间使之按照自己的方式工作。
我想使用\tableofcontents 命令,但没有目录从新页面开始或在末尾创建新页面,并且所有内容都是单倍行距。我怎样才能做到这一点?我假设使用 tocloft,但有哪些选择? 谢谢 最佳答案 试
我有一些 javascript 菜单代码,可以在单独的目录中正常工作。但是,当我尝试从同一目录中调用相同的 .js 文件时,它不会看到这些文件。 以下内容来自另一个目录: script type="t
我有这样的路径: /my/path/to/important_folder 在同一级别上,我还有其他文件和文件夹想要在达到与 important_folder 相同的级别时列出。 我的文件夹可能更深,
1、获取文件路径实现 1.1 获取当前文件路径 ? 1
我正在使用最新版本的 NTEmacs。 我写了一个名为“.dir-locals.el”的文件,如下所示。 ((nil . ((tab-width . 8) (fill-column .
关闭。这个问题不满足Stack Overflow guidelines .它目前不接受答案。 想改善这个问题吗?更新问题,使其成为 on-topic对于堆栈溢出。 7年前关闭。 Improve thi
在我的 .vimrc 中有这些行 :set foldmethod=marker :set foldmarker=SECTION:,ENDSECTION: 用于自定义代码折叠。在我的文件中,相关语言的注
在 fish 中: for x in * echo $x end *这里包括所有目录和文件,如何只列出文件(或目录)? 最佳答案 fish 没有很多花哨的通配语法。但是,目录可以像这样迭代: f
这是我的目录结构: ├── src │ ├── helpers │ │ ├── __init__.py │ │ ├── foo.py │ │ └── bar.py │
我想递归重命名文件夹/目录名称并找到 this solution所以。但是这个命令没有效果 find . -type f -exec rename 's/old/new/' '{}' \; 这是一个正
我想在相册中创建一个文件夹,并希望将图像保存在创建的相册中。 这可能吗?有什么办法可以做到这一点吗? 我已经搜索过,大多数人都说这是不可能的。 感谢您的帮助。 最佳答案 您也许可以使用AssetsLi
如何在python中使用用户定义的名称创建临时文件/目录。我知道 tempfile .但是我看不到任何以文件名作为参数的函数。 注意:我需要这个来对包含临时文件的临时目录上的 glob(文件名模式匹配
我在项目中使用JaCoCo Gradle插件。 作为问题的一个示例,我的大部分代码都在com.me.mysoftware包下。 我正在使用代码生成器来生成build/generated/java/..
我正在尝试使用 Gradle 开始运行 jar 文件 我的任务如下所示: task startServer(type: Exec) { workingDir file("${buildDir}/a
如何在 Ant 中定义一个目录集,其中包括两个目录:项目的基目录和子目录“test”? 看起来您无法使用“/”、“.”或“”专门包含目录集的根目录。例如,这包括“./test”,但不包括“.”:
我正在使用 CTAGs 包,它使用 Sublime Text 2 生成两个文件 .tags 和 .tags_sorted_by_file。 那么当我进行项目搜索(CMD + SHIFT + F)时,如
我是一名优秀的程序员,十分优秀!