- 浏览: 189533 次
- 性别:
- 来自: 北京
文章分类
最新评论
-
刘一杰:
...
Database Link详解 -
chaomc:
...
Database Link详解 -
mz0827:
这玩意儿返回的是那个字段的list
hibernate去掉重复记录 -
kadan_james:
...
Database Link详解 -
moonights:
惭愧了 这个不是俺写的.......
有关JAVA的内存泄露的文章
自己是个war3爱好者,也经常去浩方或者VS平台去打打,技术不怎么样但也偶尔去http://w3g.replays.net上去下载些replays学习学习,不过Replays_Net上的录像下载确实麻烦,每个链接都得单个点击进去才能下载,看到有人开发过mp3的批量下载器,所以想想就自己开发个类似这样的下载魔兽replays录像文件的东西,方便自己使用,也方便和我一样的war3爱好者。实现思路很简单,参考一些批量下载的程序,技术没什么新的,实用就行了。
已经修改为Form版本(有需要的留言):
主要代码如下:
War3Replays.java:
package com.moonights.war3replays; /** * * @author moonights * */ public class War3Replays { /**录像文件名称*/ private String fileName; /**录像文件大小*/ private String fileSize; /**录像文件格式*/ private String fileFormat=".w3g"; /**下载地址*/ private String fileUrl; private String savePath; public String getFileFormat() { return fileFormat; } public void setFileFormat(String fileFormat) { this.fileFormat = fileFormat; } public String getFileName() { return fileName; } public void setFileName(String fileName) { this.fileName = fileName; } public String getFileSize() { return fileSize; } public void setFileSize(String fileSize) { this.fileSize = fileSize; } public String getFileUrl() { return fileUrl; } public void setFileUrl(String fileUrl) { this.fileUrl = fileUrl; } public String getSavePath() { return savePath; } public void setSavePath(String savePath) { this.savePath = savePath; } }
War3ReplaysDowner.java:
package com.moonights.war3replays; import java.io.*; import java.net.*; import java.util.*; import java.util.regex.*; import com.moonights.utils.Configuration; import com.moonights.utils.HttpGet; /** * http://w3g.replays.net 批量下载war3Replays文件的工具,方便喜爱下载魔兽录像的人员使用. * 目前只实现到解析到二级目录下的页面,可增加递归实现多级页面解析.... * * @author moonights * */ public class War3ReplaysDowner { private static Configuration config = new Configuration("config/war3.properties"); private static String DOWNLOAD_INDEX_URL = config.getValue("DOWNLOAD_INDEX_URL"); private static String DOWNLOAD_MAIN_URL = config.getValue("DOWNLOAD_MAIN_URL");// "http://w3g.replays.net/Default.aspx?PageNo=2"; private static String FILE_SAVE_PATH = config.getValue("FILE_SAVE_PATH");// "E:\\temp"; private static String FILE_SAVE_TYPE = config.getValue("FILE_SAVE_TYPE");// ".w3g"; /** * * 只针对这种类型的url:<a * href="http://w3g.replays.net/doc/cn/2010-1-25/12644174774532572561.html" * target="_blank">* */ private static final String url_regexp_resources = "<a href=\"(\\w+://[^/:]+[^#\\s]*)\" target=\"_blank\">"; private static final String url_regexp_downloadFile = "<a href=\"(.*?)\">Download REP</a>"; private static final String url_regexp_downloadFileName = "<h3><span id=\"ctl00_Content_labTitle\">(.*?)</span></h3>"; /** * 根据 URL 读取应对页面的HTML源码 * * @param url * 文件的URL * @return String URL应对页面的HTML源码, 如果连接到指定URL, 则返回一个空字符串("") */ public String getHtmlCode(String url) { try { URL u = new URL(url); URLConnection urlConnection = u.openConnection(); urlConnection.setAllowUserInteraction(false); // 使用openStream得到一输入流并由此构造一个BufferedReader对象 BufferedReader in = new BufferedReader(new InputStreamReader(u .openStream())); String inputLine; StringBuffer tempHtml = new StringBuffer(); while ((inputLine = in.readLine()) != null) { // 从输入流不断的读数据,直到读完为止 tempHtml.append(inputLine).append("\n"); } return tempHtml.toString(); } catch (IOException e) { return ""; } } /** * 根据 URL 读取应对页面的HTML源码 * * @param url * 文件的URL * @return String URL应对页面的HTML源码, 如果连接到指定URL, 则返回一个空字符串("") */ public static String getHtml(String urlString) { try { StringBuffer html = new StringBuffer(); URL url = new URL(urlString); HttpURLConnection conn = (HttpURLConnection) url.openConnection(); InputStreamReader isr = new InputStreamReader(conn.getInputStream()); BufferedReader br = new BufferedReader(isr); String temp; while ((temp = br.readLine()) != null) { html.append(temp).append("\n"); } br.close(); isr.close(); return html.toString(); } catch (Exception e) { e.printStackTrace(); return null; } } /** * 根据url获取该url页面中的所有包含下载资源的url链接() 只针对这种类型的url:<a * href="http://w3g.replays.net/doc/cn/2010-1-25/12644174774532572561.html" * target="_blank"> * * @param 文件的URL * @return List * URL应对页面中的所有指定URL:http://w3g.replays.net/doc/cn/2010-1-25/12644174774532572561.html */ public List<String> getUrlByURLPage(String url) { List<String> list = new ArrayList<String>(); String htmlCode = getHtmlCode(url); Pattern p = Pattern.compile(url_regexp_resources, Pattern.CASE_INSENSITIVE); Matcher matcher = p.matcher(htmlCode); String id = null; while (matcher.find()) { id = matcher.group(1); if (!list.contains(id)) { list.add(id); } } return list; } /** * 根据获取的包含下载资源的url查询下载资源url连接以及文件名称 (文件名如下:[SW]GaB.RohJinWook vs ieS.Check * #1.w3g,解析页面中的标题获取,中文有乱码,和手动下载的名称不一致但类似) * * @param List * @return Vector * {("http://w3g.replays.net/Download.aspx?ReplayID=41162&File=%2fReplayFile%2f2010-1-26%2f100126_%5bUD%5dfantafiction_VS_%5bORC%5dmmmgbp_TwistedMeadows_RN.w3g", * "e:\\temp\\dmmmgbp_TwistedMeadows_RN.w3g")} */ public Vector getWar3ReplaysByTitle(List url_list) { Vector vector = new Vector(); for (int i = 0; i < url_list.size(); i++) { String temp_url = url_list.get(i).toString(); String temp_htmlCode = this.getHtmlCode(temp_url); String fileUrl = getMatcher(url_regexp_downloadFile, temp_htmlCode, 1); String fileName = getMatcher(url_regexp_downloadFileName, temp_htmlCode, 1); if (!fileUrl.equals("") && !fileName.equals("")) { War3Replays war3Replays = new War3Replays(); fileUrl = DOWNLOAD_INDEX_URL + fileUrl;// 将相对URL修改为绝对URL // fileName = FILE_SAVE_PATH+"\\"+fileName+FILE_SAVE_TYPE;// war3Replays.setFileName(fileName); war3Replays.setFileUrl(fileUrl); war3Replays.setSavePath(this.FILE_SAVE_PATH); war3Replays.setFileFormat(this.FILE_SAVE_TYPE); vector.add(war3Replays); } if (i > 0 && i % 10 == 0) { // 每循环10次后休息2秒再进行请求, 否则可能被当作网络攻击 try { Thread.sleep(2000); System.out .println(">>>>>>>>>>>>>>>>>>>暂停页面抓取,2秒后继续<<<<<<<<<<<<<<<<<<<<<<"); } catch (InterruptedException e) { e.printStackTrace(); } } } return vector; } /** * 根据获取的包含下载资源的url链接查询下载War3Replays文件 * (文件名如下:_ReplayFile_2010-1-24_100124__NE_mTw.DIDI8_VS__HM_VeryB1gman._AncientIsles_RN.w3g,解析url获取的) * 待优化:待简略一些.. * * @param url_list * @return */ public Vector getWar3ReplaysByUrl(List url_list) { Vector vector = new Vector(); for (int i = 0; i < url_list.size(); i++) { String temp_url = url_list.get(i).toString(); String temp_htmlCode = this.getHtmlCode(temp_url); String fileUrl = getMatcher(url_regexp_downloadFile, temp_htmlCode, 1); if (!fileUrl.equals("")) { War3Replays war3Replays = new War3Replays(); fileUrl = DOWNLOAD_INDEX_URL + fileUrl;// 将相对URL修改为绝对URL war3Replays.setFileUrl(fileUrl); String regex = "&File=(.*?).w3g"; String fileName = getMatcher(regex, fileUrl, 1); fileName = fileName.replaceAll("(%2f|%5b|%5d)", "_"); war3Replays.setFileName(fileName); war3Replays.setSavePath(this.FILE_SAVE_PATH); war3Replays.setFileFormat(this.FILE_SAVE_TYPE); vector.add(war3Replays); } if (i > 0 && i % 10 == 0) { // 每循环10次后休息2秒再进行请求, 否则可能被当作网络攻击 try { Thread.sleep(2000); System.out .println(">>>>>>>>>>>>>>>>>>>暂停页面抓取,2秒后继续<<<<<<<<<<<<<<<<<<<<<<"); } catch (InterruptedException e) { e.printStackTrace(); } } } return vector; } public static String getMatcher(String regex, String source, int group) { String result = ""; Pattern pattern = Pattern.compile(regex, Pattern.CASE_INSENSITIVE); Matcher matcher = pattern.matcher(source); while (matcher.find()) { result = matcher.group(group); } return result; } /** * 下载获取到的war3replays录像文件 方法一 */ public void downWar3Replays_WAY1() { List url_list = this.getUrlByURLPage(DOWNLOAD_MAIN_URL); Vector vector = this.getWar3ReplaysByUrl(url_list); HttpGet downer = new HttpGet(); if (vector.size() > 0) { for (int i = 0; i < vector.size(); i++) { War3Replays war3Replays = (War3Replays) vector.get(i); try { // 增加下载列表(此处用户可以写入自己代码来增加下载列表) downer.addItem(war3Replays.getFileUrl(), war3Replays .getSavePath() + "\\" + war3Replays.getFileName() + war3Replays.getFileFormat()); // 开始下载 } catch (Exception err) { System.out.println(err.getMessage()); } } System.out.println("开始下载."); downer.downLoadByList(); System.out.println("下载完毕."); } } /** * 下载获取到的war3replays录像文件 方法二 */ public void downWar3Replays_WAY2() { List url_list = this.getUrlByURLPage(DOWNLOAD_MAIN_URL); Vector vector = this.getWar3ReplaysByTitle(url_list); HttpGet downer = new HttpGet(); if (vector.size() > 0) { for (int i = 0; i < vector.size(); i++) { War3Replays war3Replays = (War3Replays) vector.get(i); try { // 增加下载列表(此处用户可以写入自己代码来增加下载列表) downer.addItem(war3Replays.getFileUrl(), war3Replays .getSavePath() + "\\" + war3Replays.getFileName() + war3Replays.getFileFormat()); // 开始下载 } catch (Exception err) { System.out.println(err.getMessage()); } } System.out.println("开始下载."); downer.downLoadByList(); System.out.println("下载完毕."); } } }
HttpGet.java:
package com.moonights.utils; import java.io.*; import java.net.*; import java.util.*; /** * Description: 将指定的HTTP网络资源在本地以文件形式存放 */ public class HttpGet { public final static boolean DEBUG = true;// 调试用 private static int BUFFER_SIZE = 8096;// 缓冲区大小 private Vector vDownLoad = new Vector();// URL列表 private Vector vFileList = new Vector();// 下载后的保存文件名列表 /** * 构造方法 */ public HttpGet() { } /** * 清除下载列表 */ public void resetList() { vDownLoad.clear(); vFileList.clear(); } /** * 增加下载列表项 * * @param url * String * @param filename * String */ public void addItem(String url, String filename) { vDownLoad.add(url); vFileList.add(filename); } /** * 根据列表下载资源 */ public void downLoadByList() { String url = null; String filename = null; // 按列表顺序保存资源 for (int i = 0; i < vDownLoad.size(); i++) { url = (String) vDownLoad.get(i); filename = (String) vFileList.get(i); try { saveToFile(url, filename); } catch (IOException err) { if (DEBUG) { System.out.println("资源[" + url + "]下载失败!!!"); } } /*if(i>0 && i%5==0){ // 每循环5次后休息2秒再进行请求, 否则可能被当作网络攻击 try { //Thread.sleep(2000); //System.out.println(">>>>>>>>>>>>>>>>>>>暂停下载,2秒后继续<<<<<<<<<<<<<<<<<<<<<<"); }catch (InterruptedException e) { e.printStackTrace(); } }*/ } if (DEBUG) { System.out.println("下载完成!!!"); } } /** * 将HTTP资源另存为文件 * * @param destUrl * String * @param fileName * String * @throws Exception */ public void saveToFile(String destUrl, String fileName) throws IOException { FileOutputStream fos = null; BufferedInputStream bis = null; HttpURLConnection httpUrl = null; URL url = null; byte[] buf = new byte[BUFFER_SIZE]; int size = 0; // 建立链接 url = new URL(destUrl); httpUrl = (HttpURLConnection) url.openConnection(); // 连接指定的资源 httpUrl.connect(); // 获取网络输入流 bis = new BufferedInputStream(httpUrl.getInputStream()); // 建立文件 fos = new FileOutputStream(fileName); //判断是否存在该文件,如果存在将文件名称修改为另外一个。。。。 if (this.DEBUG) System.out.println("正在获取链接[" + destUrl + "]的内容...\n将其保存为文件[" + fileName + "]"); // 保存文件 while ((size = bis.read(buf)) != -1) fos.write(buf, 0, size); fos.close(); bis.close(); httpUrl.disconnect(); } /** * 设置代理服务器 * * @param proxy * String * @param proxyPort * String */ public void setProxyServer(String proxy, String proxyPort) { // 设置代理服务器 System.getProperties().put("proxySet", "true"); System.getProperties().put("proxyHost", proxy); System.getProperties().put("proxyPort", proxyPort); } /** * 设置认证用户名与密码 * * @param uid * String * @param pwd * String */ /*public void setAuthenticator(String uid, String pwd) { Authenticator.setDefault(new MyAuthenticator(uid, pwd)); }*/ /** * 主方法(用于测试) * * @param argv * String[] */ public static void main(String argv[]) { HttpGet oInstance = new HttpGet(); try { // 增加下载列表(此处用户可以写入自己代码来增加下载列表) oInstance.addItem("http://xiazai.xiazaiba.com/0905/0504/2k3IIS6_XiaZaiBa.rar","e:\\temp\\iis6_2.rar"); // 开始下载 oInstance.downLoadByList(); } catch (Exception err) { System.out.println(err.getMessage()); } } }
Configuration.java:
package com.moonights.utils; import java.io.FileInputStream; import java.io.FileNotFoundException; import java.io.FileOutputStream; import java.io.IOException; import java.io.InputStream; import java.util.Properties; /** * 读取properties文件 * @author moonights * */ public class Configuration { private Properties propertie; private InputStream inputFile; private FileOutputStream outputFile; /** * 初始化Configuration类 */ public Configuration(){ propertie = new Properties(); } /** * 初始化Configuration类 * @param filePath 要读取的配置文件的路径+名称 */ public Configuration(String filePath){ propertie = new Properties(); try { //inputFile = (InputStream) this.getClass().getResourceAsStream(filePath); inputFile = this.getClass().getClassLoader().getResourceAsStream(filePath); propertie.load(inputFile); inputFile.close(); } catch (FileNotFoundException ex) { System.out.println("读取属性文件--->失败!- 原因:文件路径错误或者文件不存在"); ex.printStackTrace(); } catch (IOException ex) { System.out.println("装载文件--->失败!"); ex.printStackTrace(); } }//end ReadConfigInfo() /** * 重载函数,得到key的值 * @param key 取得其值的键 * @return key的值 */ public String getValue(String key){ if(propertie.containsKey(key)){ String value = propertie.getProperty(key);//得到某一属性的值 return value; } else return ""; } /** * 重载函数,得到key的值 * @param fileName properties文件的路径+文件名 * @param key 取得其值的键 * @return key的值 */ public String getValue(String fileName, String key){ try { String value = ""; inputFile = new FileInputStream(fileName); propertie.load(inputFile); inputFile.close(); if(propertie.containsKey(key)){ value = propertie.getProperty(key); return value; }else return value; } catch (FileNotFoundException e) { e.printStackTrace(); return ""; } catch (IOException e) { e.printStackTrace(); return ""; } catch (Exception ex) { ex.printStackTrace(); return ""; } }//end getValue() /** * 清除properties文件中所有的key和其值 */ public void clear(){ propertie.clear(); }//end clear(); /** * 改变或添加一个key的值,当key存在于properties文件中时该key的值被value所代替, * 当key不存在时,该key的值是value * @param key 要存入的键 * @param value 要存入的值 */ public void setValue(String key, String value){ propertie.setProperty(key, value); }//end setValue() /** * 将更改后的文件数据存入指定的文件中,该文件可以事先不存在。 * @param fileName 文件路径+文件名称 * @param description 对该文件的描述 */ public void saveFile(String fileName, String description){ try { outputFile = new FileOutputStream(fileName); propertie.store(outputFile, description); outputFile.close(); } catch (FileNotFoundException e) { e.printStackTrace(); } catch (IOException ioe){ ioe.printStackTrace(); } }//end saveFile() /** * 测试 * @param args */ }
Main.java:程序入口
package com.moonights.war3replays; /** * 程序入口。 * @author moonights * */ public class Main { public static void main(String[] args) { War3ReplaysDowner war3_Downer = new War3ReplaysDowner(); //war3_Downer.downWar3Replays_WAY1(); war3_Downer.downWar3Replays_WAY2(); } }
war3.properties:配置文件
##下载首页面 DOWNLOAD_INDEX_URL = http://w3g.replays.net ##下载主页面(修改该变量即可) DOWNLOAD_MAIN_URL = http://w3g.replays.net/ReplayList.aspx?GameRace=3&PageNo=6 ##灵活下载多个页面中的资源 (暂时未实现) PageNo=5 MAX_PageNo=50 ##文件保存路径 FILE_SAVE_PATH=F:\\1.22\\hum ##文件格式 FILE_SAVE_TYPE=.w3g
程序还有挺多需要改进的地方,文件路径必须先有,时间问题没有做过多的考虑,希望有哪位提提意见,优化一下。如果有人修改成界面的,那就更好了。
评论
1 楼
498204396
2010-11-29
你好啊。能给我一个form版本吗?我的电邮地址是:498204396@qq.com,还请楼主百忙之中给我发一份啊。非常感谢。。我也是一个魔兽游戏爱好者。
发表评论
-
Android推送服务器
2014-11-02 18:03 399NIO实现的 Socket底层数据传输框架 参考了mi ... -
修改配置文件动态生效
2013-01-23 15:05 1115在我们的应用中,会经常性的修改配置文件,但是往往web应 ... -
桶排序
2012-04-06 08:53 1040优点:一种十分巧妙的排序方式,排序速度也很快。 缺点:排序是 ... -
一个惯性思维出现的错误-有点意思
2011-11-22 16:52 1939很久没有积累东西了,碰巧前几天遇到一个的问题,虽然不大但是比较 ... -
知识积累—Java内存泄露问题分析(转)
2011-06-29 10:35 952个人转载的一篇文章,可以对内存泄露的问题理解多一些,其中标红的 ... -
有关JAVA的内存泄露的文章
2011-06-29 10:34 1568Java的一个重要优点就是通过垃圾收集器GC (Garbag ... -
proxool连接池监听配置
2011-06-27 14:36 1398连接池监听<servlet> <servl ... -
JSF中的FacesContext对象详解
2011-03-21 11:10 1349JSF中的FacesContext对象详 ... -
Java NIO原理和使用
2011-02-18 13:32 853Java NIO原理和 ... -
java 栈和堆的比较
2011-02-18 13:22 640From : http://www.j2medev ... -
问题积累—解决Windows不能在本地计算机启动apache tomcat
2010-07-03 11:48 2311错误描述:在windows下以服务的方式启动时提示如下: “w ... -
收藏整理—常用正则表达式
2010-06-01 14:41 6141。^\d+$ //匹配非负整数(正整数 + 0) 2。 ... -
递归删除目录和文件
2010-06-01 11:17 832import java.io.*; ... -
java实现基于http协议的网络文件下载
2010-01-26 13:50 14961.HTTP协议工作方式 基于HTTP协议的客户/服务 ... -
java.net.URL的URL构建方式
2010-01-26 13:47 1620认识IP、认识URL是进行网络编程的第一步。java.net. ... -
Java中的几个术语的解释与关系
2010-01-07 15:54 705java的几种对象(PO,VO,DAO,BO,POJO)解释 ... -
JAVA 中URL链接中文参数乱码的处理方法
2010-01-07 09:11 1019JAVA 中URL链接中文参数乱码的若干处理方法,现在整理收录 ... -
怎样用Java来获取真实的IP地址
2009-08-06 10:10 967在JSP里,获取客户端的IP地址的方法是:reque ... -
java实现外部调用exe文件
2009-07-31 12:35 788package com.moonights.tools; / ... -
java实现MD5加密算法
2009-07-30 08:44 1056package com.moonights.tools; ...
相关推荐
点击replay:会自动下载replay文件和相应的地图,并打开war3,“一键”在线看录像 点击download:只自动下载replay文件和相应的地图,不打开war3 点击lingk,链接到 ...
风暴英雄录像播放器支持最新版游戏录像文件,设置游戏路径后可...选择要加载的录像文件,建议先选择播放器下Replays内附带的两场对战录像进行测试 4.点击开启游戏,进入登录界面后选择加载录像. 更新日志:1.增加了录
#replays ##todo 时间戳创建图表(接近完成)通过反转 y 值等(接近完成)将重播转换为 HR ##格式 字节 - 游戏模式 int32 - 文件版本 字符串 - beatmap md5 哈希 字符串 - 用户名 字符串 - 重播哈希 uint16 - 300...
2. **download.php**:处理下载请求的脚本,可能负责验证权限并提供重播文件的下载链接。 3. **config.php**:配置文件,可能包含了数据库连接信息、站点设置等关键参数。 4. **install-dl.php**:安装脚本,帮助...
"shogun_2_replays-main"可能是一个包含多个战斗重播文件的目录,其中包含了不同玩家、不同战术、不同阶段的战斗案例。通过对这些文件的研究,玩家可以深入理解《幕府将军2》的战斗机制,掌握更丰富的战术组合,甚至...
这是我正在慢慢进行的项目。 我利用它作为学习一些新事物的机会。 即... ES6 Webpack React 助焊剂(Redux) Immutable.js 码头工人 码头工人 要构建Docker映像...... docker build -t ryancole/dank-api .
replays.animalsofttheforest.rocks 一个 node.js 网络应用程序,用于在更长的时间内获取和存储 dota2 重播文件。 安装 $ npm install $ gulp 环境变量 必须设置这些变量才能使应用程序正常工作。 名称 描述 示例...
在IT行业中,流媒体(Stream Media)是指通过网络连续传输音视频内容的技术,而不是一次性下载整个文件。这种技术广泛应用于在线视频平台、游戏直播等场景。游戏回放(Game Replays)则允许用户记录并回放游戏过程,...
这个`HLP_WOT_Replays.crx`文件包含了插件的所有代码和资源,用户可以直接将其拖入到Chrome浏览器的扩展管理页面进行安装。这种安装方式简单快捷,使得非技术背景的玩家也能轻松使用。 使用HLP WOT Replays-crx插件...
它允许用户上载他们的Rocket League .replay文件,进行分析并显示数据。 该存储库包含运行该应用程序所需的所有代码,以及用于处理数据的辅助服务。 安装 Rocket League Replays仅适用于Python 3,与Python 2不...
MygosuClan是星际争霸和魔兽世界部族的内容管理系统。 更新内容: - 修正了许多错误,可以在最新版本的PHP/MySQL脚本工作,测试:PHP 4.4.4,PHP 5.3.1,MySQL 5.x - 改进的错误处理 - smarty升级到2.6.25 ...
通常这会涉及下载软件安装包,以及根据安装向导完成安装过程。 - **运行OrcaFlex**: 安装完成后,用户可以通过启动程序来运行OrcaFlex,并对程序进行配置和优化以适应不同的分析需求。 - **并行处理(Parallel ...
"MLE_advanced_metrics_raw_replays"项目就是针对这样的需求而设计的,它利用原始的游戏重放数据来为MLE(可能是Multiplayer Online Game的League或者某种特定游戏的缩写)统计团队生成一系列高级指标。这些指标可以...
通过Shell,玩家可以编写自定义脚本来批量处理大量的Slippi重播文件,比如提取特定的数据、统计胜率或比较不同玩家的表现。 在"slippi-replays-master"这个文件名中,我们可以推测这可能是一个包含多个Slippi重播...
这些文件默认位于下您的文档League of Legends/Replays的文件夹,并有.rofl extention(L eague的[R eplay)。入门安装您首先需要通过库或来安装库。用法首先,您需要处理League对象。 该对象将为您提供有关已安装...
`replays`文件夹可能存储了玩家的游戏回放记录,允许用户回顾和分析自己的游戏过程。通过这样的功能,开发者可以更好地理解玩家的行为模式,从而优化游戏设计。 `maps`文件夹则可能包含了各种不同的游戏地图,每个...
4. **replays**:这个文件夹可能存储了玩家的游戏回放记录,允许玩家回顾自己的游戏过程或者分享给其他人。回放系统通常会记录每个步骤的动作,以便于再现游戏状态。 5. **images**:图像资源文件夹,通常包含了...
- 查找并编辑WebLogic的`commonEnv.sh`文件中的`max-nofiles`值,以允许更多的文件打开。 #### 五、Has shutdown the connection prematurely **问题描述:** “Has shutdown the connection prematurely”问题...
AWC也可以和WAR3中的.w3g文件相关联,所以当你想要看WAR3 的REPLAYS时就只要双击它就可以了。它也能在许多著名的REPLAY 播放器(如W3gMaster, Replay ToolKit)的主界面中加入了View Replay这个功能。 <br> ...
python-hsreplay 用于HSReplay支持的python模块。... 该类包含导入和导出HSReplay文件的所有必要功能。读/写HSReplay XML文件来自from_xml_file(fp)采用类似文件的对象,并将返回一个文档。 如果已经有El