背景:  android studio 在无法下载依赖的情况下 , 仅 使用 mavenLocal()

本地 .gradle 下有对应依赖 , .m2下没有

故将.gradle下的 带hash名称文件夹中的依赖 转换为 .m2上的依赖

import os
import io
import sys
sys.stdout=io.TextIOWrapper(sys.stdout.buffer,encoding='utf8') patho = '' def backup_file(path, path_two):
path = get_gradle_path(path_two)
path_two = path_two.replace('/', '\\')
print (path_two)
if not os.path.exists(path_two):
os.makedirs(path_two)
"""
:param path: 路径1
:param path_two: 路径2
:return:
"""
if os.path.isdir(path) and os.path.isdir(path_two): # 判断传入的值为文件夹
a = os.listdir(path) # 读取该路径下的文件为列表
print (a[0])
print (len(a))
# if os.path.isdir(path_two):
for i in a:
if os.path.isdir(path + '\\' + i): # 判断传入的值为文件夹
patho = path + '\\' + i
af = os.listdir(patho) # 读取该路径下的文件为列表
print (af)
for m in af:
po = os.path.join(patho, m) # 路径1拼接
po_two = os.path.join(path_two, m) # 路径2拼接
with open(po, "rb") as f:
res_one = f.read()
with open(po_two, "wb") as a:
a.write(res_one)
print("{}复制成功".format(i))
else:
po = os.path.join(path, i) # 路径1拼接
po_two = os.path.join(path_two, i) # 路径2拼接
with open(po, "rb") as f:
res_one = f.read()
with open(po_two, "wb") as a:
a.write(res_one)
print("{}复制成功".format(i))
else:
print("不是文件夹") path_two = ''
pathsimple = r'D:\xxxxx\workspace\.gradle\caches\modules-2\files-2.1'
def get_gradle_path(pathtwo):
ones = pathtwo.split('/')
print (ones)
pathsimple = r'D:\xxxxx\workspace\.gradle\caches\modules-2\files-2.1'
for m in range(len(ones) - 5):
print (ones[m + 5])
pathsimple += '\\' + ones[m + 5]
res = ''
if len(ones) == 8:
sims = pathsimple.split('\\')
index = 0
for m in sims:
res += m + '\\'
index += 1
if len(ones) == 9:
sims = pathsimple.split('\\')
index = 0
for m in sims:
if index == 7 :
res += m + '.'
else:
res += m + '\\'
index += 1
if len(ones) == 10:
sims = pathsimple.split('\\')
index = 0
for m in sims:
if index == 7 or index == 8:
res += m + '.'
else:
res += m + '\\'
index += 1
if len(ones) == 11:
sims = pathsimple.split('\\')
index = 0
for m in sims:
if index == 7 or index == 8 or index == 9:
res += m + '.'
else:
res += m + '\\'
index += 1
if len(ones) == 12:
sims = pathsimple.split('\\')
index = 0
for m in sims:
if index == 7 or index == 8 or index == 9 or index == 10:
res += m + '.'
else:
res += m + '\\'
index += 1
print (res)
if os.path.exists(res):
print ('转换后的 gradle地址 存在', res)
else:
print ('不存在,请手动传递地址')
return res
# get_gradle_path('C:/Users/xxxxx/.m2/repository/com/googlecode/json-simple/json-simple/1.1')
# backup_file('', 'C:/Users/xxxxx/.m2/repository/com/zhy/autolayout/1.4.5') def getbypath (path):
pathtwoin = 'C:/Users/xxxxx/.m2/repository'
paths = path.split(':')
pathsone = paths[0].split('.')
print (pathsone)
print (paths)
index = 0
for p in paths:
if index == 0:
for pa in pathsone:
pathtwoin += '/' + pa
else :
pathtwoin += '/' + p
index += 1
print (pathtwoin)
backup_file('', pathtwoin) getbypath('com.squareup.okhttp3:okhttp:3.8.0') def listpath (need_path):
# need_path = ['com.android.support:support-compat:26.1.0',
# 'com.android.support:support-media-compat:26.1.0',
# 'com.android.support:support-core-utils:26.1.0',
# 'com.android.support:support-core-ui:26.1.0']
print (need_path[0])
print (len(need_path))
for pat in need_path:
getbypath(pat) # listpath() def get_file_list():
data = []
for line in open(r'C:\\Users\\xxxxx\\Desktop\\test.txt',"r"): #设置文件对象并读取每一行文件
if 'resolve' in line:
data.append(line[26:-1]) #将每一行文件加入到list中
print (data)
listpath(data) # get_file_list() # get_file_list() 根据指定的文件地址,查询文件中包含 resolve的行,并截取对应的依赖名称
# listpath() 根据指定的插件list,获取本地的 .m2 的路径,若没有则创建对应路径
# getbypath() 根据指定的插件名称,获取本地的 .m2 的路径,若没有则创建对应路径
# backup_file() 根据指定路径 把 对应的 .gradle\caches\modules-2\files-2.1 下的依赖 copy到.m2 对应的路径下

---------------------------------------------------------------------------------------------

上半部分是可以单独copy指定的依赖

下面是全部转换,使用的时候,全局替换一下gradle缓存和.m2地址对应的字符串即可

----------------------------------------------------------------------------------------------

import os
import io
import sys
sys.stdout=io.TextIOWrapper(sys.stdout.buffer,encoding='utf8')
# 将 caches\modules-2\files-2.1 下的 依赖格式 都修改为 .m2格式的依赖
# 1. 获取files-2.1下的路径
# 2. for 循环 获取文件夹名称, 再获取下一层,下下一层的文件名称 ,然后组装为依赖名
patho = '' def backup_file(path, path_two):
path = get_gradle_path(path_two)
path_two = path_two.replace('/', '\\')
print (path_two)
if not os.path.exists(path_two):
os.makedirs(path_two)
"""
:param path: 路径1
:param path_two: 路径2
:return:
"""
if os.path.isdir(path) and os.path.isdir(path_two): # 判断传入的值为文件夹
a = os.listdir(path) # 读取该路径下的文件为列表
print (a[0])
print (len(a))
# if os.path.isdir(path_two):
for i in a:
if os.path.isdir(path + '\\' + i): # 判断传入的值为文件夹
patho = path + '\\' + i
af = os.listdir(patho) # 读取该路径下的文件为列表
print (af)
for m in af:
po = os.path.join(patho, m) # 路径1拼接
po_two = os.path.join(path_two, m) # 路径2拼接
with open(po, "rb") as f:
res_one = f.read()
with open(po_two, "wb") as a:
a.write(res_one)
print("{}复制成功".format(i))
else:
po = os.path.join(path, i) # 路径1拼接
po_two = os.path.join(path_two, i) # 路径2拼接
with open(po, "rb") as f:
res_one = f.read()
with open(po_two, "wb") as a:
a.write(res_one)
print("{}复制成功".format(i))
else:
print("不是文件夹") path_two = ''
pathsimple = r'D:\xxxxxxx\workspace\.gradle\caches\modules-2\files-2.1'
def get_gradle_path(pathtwo):
ones = pathtwo.split('/')
print (ones)
pathsimple = r'D:\xxxxxxx\workspace\.gradle\caches\modules-2\files-2.1'
for m in range(len(ones) - 5):
print (ones[m + 5])
pathsimple += '\\' + ones[m + 5]
res = ''
if len(ones) == 8:
sims = pathsimple.split('\\')
index = 0
for m in sims:
res += m + '\\'
index += 1
if len(ones) == 9:
sims = pathsimple.split('\\')
index = 0
for m in sims:
if index == 7 :
res += m + '.'
else:
res += m + '\\'
index += 1
if len(ones) == 10:
sims = pathsimple.split('\\')
index = 0
for m in sims:
if index == 7 or index == 8:
res += m + '.'
else:
res += m + '\\'
index += 1
if len(ones) == 11:
sims = pathsimple.split('\\')
index = 0
for m in sims:
if index == 7 or index == 8 or index == 9:
res += m + '.'
else:
res += m + '\\'
index += 1
if len(ones) == 12:
sims = pathsimple.split('\\')
index = 0
for m in sims:
if index == 7 or index == 8 or index == 9 or index == 10:
res += m + '.'
else:
res += m + '\\'
index += 1
print (res)
if os.path.exists(res):
print ('转换后的 gradle地址 存在', res)
else:
print ('不存在,请手动传递地址')
return res def getbypath (path):
pathtwoin = 'D:/xxxxxxx/workspace/.m2/repository'
paths = path.split(':')
pathsone = paths[0].split('.')
print (pathsone)
print (paths)
index = 0
for p in paths:
if index == 0:
for pa in pathsone:
pathtwoin += '/' + pa
else :
pathtwoin += '/' + p
index += 1
print (pathtwoin)
backup_file('', pathtwoin) def listpath (need_path):
print (need_path[0])
print (len(need_path))
for pat in need_path:
getbypath(pat) def get_dependencies():
files_path = r'D:\xxxxxxx\workspace\.gradle\caches\modules-2\files-2.1';
dependencies_data = []
if os.path.isdir(files_path): # 判断传入的值为文件夹
dirstpath = os.listdir(files_path) # 读取该路径下的文件为列表
for i in dirstpath:
if os.path.isdir(files_path + '\\' + i): # 判断传入的值为文件夹
path1 = path1 = files_path + '\\' + i
dirstpath1 = os.listdir(path1)
for i1 in dirstpath1:
path2 = path1 + '\\' + i1
if os.path.isdir(path2): # 判断传入的值为文件夹
dirstpath2 = os.listdir(path2)
for i2 in dirstpath2:
str = i + ':' + i1 + ':' + i2
dependencies_data.append(str)
print (dependencies_data)
listpath(dependencies_data) get_dependencies()

  

将.gradle下的 带hash名称文件夹中的依赖 转换为 .m2上的依赖的更多相关文章

  1. Selector、shape详解,注意这两种图像资源都以XML方式存放在drawable不带分辨率的文件夹中

    Selector.shape详解(一) Selector的结构描述: <?xml version="1.0" encoding="utf-8"?> ...

  2. python批量修改一个文件夹下含多个文件夹中的所有图片名称

    网上能找到的,大多是只对一个文件夹下所有图片进行重命名的代码. 这边实现的是,一个文件夹下有多个文件夹内图片的重命名. rename.py #!/usr/bin/python # -*- coding ...

  3. Tomcat下webapps夹中root文件夹作用及如何发布项目至root文件夹中

    转载请注明出处: tomcat的root文件夹下面默认是tomcat的管理程序,但是如果你把自己的web项目发布到root下面的话,你可以不通过项目名直接访问你的项目,比如,你见了一个名为Test的项 ...

  4. apk当安装程序将文件复制到手机自带的指定文件夹

    项目已获得,今天.apk文件以获得另一个非调试手机,发现一个问题. 由于涂料.所以绘图数据的点存储在一个.txt文字档.把它用usb传到指定目录下的,可是明显不科学,由于用户下载了你的.apk文件,你 ...

  5. php获取指定文件夹中文件名称

    /** * php获取指定文件夹中文件名称 * @author jackie <2018.10.10> */ public static function getFileName($fil ...

  6. [R语言]读取文件夹下所有子文件夹中的excel文件,并根据分类合并。

    解决的问题:需要读取某个大文件夹下所有子文件夹中的excel文件,并汇总,汇总文件中需要包含的2部分的信息:1.该条数据来源于哪个子文件夹:2.该条数据来源于哪个excel文件.最终,按照子文件夹单独 ...

  7. java基础 File 递归删除文件夹中所有文件文件夹 目录(包含子目录)下的.java文件复制到e:/abc文件夹中, 并统计java文件的个数

    File 递归删除文件夹中所有文件文件夹 package com.swift.kuozhan; import java.io.File; import java.util.Scanner; /*键盘录 ...

  8. windows下使用RoboCopy命令进行文件夹增量备份

    RoboCopy,它是一个命令行的目录复制命令,自从Windows NT 4.0 开始就成为windows 资源工具包的一部分,然后在Windows Vista.Windows 7和 Windows ...

  9. iis7下查看站点日志对应文件夹

    原文:iis7下查看站点日志对应文件夹 IIS7下面默认日志文件的存放路径:%SystemDrive%\inetpub\logs\LogFiles 查看方法:点击对应网站 -> 右侧功能视图 - ...

  10. 使用linq获得当前文件夹下的下一级满足条件的文件夹

    使用linq获得当前文件夹下的下一级满足条件的文件夹.             SPFolderCollection subAlbums = Folder.SubFolders;            ...

随机推荐

  1. Me-and-My-Girlfriend-1靶机渗透流程

    Me-and-My-Girlfriend-1 靶机下载 Description: This VM tells us that there are a couple of lovers namely A ...

  2. 深度学习pytorch常用操作以及流程

    在微信公众号上看到这篇文章,担心以后想找的时候迷路,所以记录到了自己的博客上,侵扰致歉,随时联系可删除. 1.基本张量操作 1. 1 创建张量 介绍: torch.tensor() 是 PyTorch ...

  3. [无线隔离]同一WIFI下两主机无法互联

    问题描述 在公司WIFI下想进行两台主机之间的数据传输,却发现虽在同一网段且防火墙关闭也无法ping通. 在一台主机下查看ARP表,发现没有对方的IP与MAC记录. 使用Wireshark抓包,发现虽 ...

  4. ElementUI Dialog 结合Vue实现对话框body“二分”布局

    Dialog 结合Vue实现对话框body"二分"布局 需求描述 如下图, 把对话框body内容部分,分成上下两部分,其中上部分高度根据窗口大小动态调整,如果内容过多,则出现滚动条 ...

  5. Vue 新增不参与打包的接口地址配置文件

    Vue 新增不参与打包的接口地址配置文件   by:授客 QQ:1033553122   开发环境   Win 10   Vue 2.5.2 问题描述 vue工程项目,npm run build we ...

  6. CF30D King's Problem? 题解

    CF30D 题意 有 \(n+1\) 个点,其中的 \(n\) 个点在数轴上.求以点 \(k\) 为起点走过所有点的最短距离,允许重复. 思路 有两种情况: \(k\) 在数轴上(如图1). \(k\ ...

  7. [UE] 关于ue5中制作流日志记录

    UE5目前根据现有功能,配合Quixel Bridge可以做到地编和一些简单的动画,实现完整的游戏,但是目前随着版本的迭代,流程的定制需要更新 ControlRig方便在UE中做动画的,模拟动画等,U ...

  8. 【OracleDB】 03 数据类型和常见对象概述

    我们可以通过PLSQL来查看Oracle的数据类型 总分类: - 字符型 1.CHAR 0 - 2000 字节 固定长度字符串 2.NCHAR 0 - 1000 字节 固定长度字符串[Unicode字 ...

  9. 【Hibernate】Re07 关系映射处理

    一.单向多对一关系映射处理 演示案例列举了员工与部门的关系,一个部门下具有多个员工,相反的一个员工只隶属于一个部门下面 Maven依赖坐标: <dependency> <groupI ...

  10. Jax框架的性能分析——性能分析可视化

    官方文档: https://jax.readthedocs.io/en/latest/profiling.html 将jax代码的性能文件写入到文件夹中,并给出上传第三方网站的链接生成(https:/ ...