Android имеет функцию «PdfDocument», чтобы достичь этого,
class Main2Activity : AppCompatActivity() {
private var imgFiles: Array<File?>? = null
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_main2)
imgFiles= arrayOfNulls(2)
imgFiles!![0] = File(Environment.getExternalStoragePublicDirectory(Environment.DIRECTORY_PICTURES).toString() + "/doc1.png")
imgFiles!![1] = File(Environment.getExternalStoragePublicDirectory(Environment.DIRECTORY_PICTURES).toString() + "/doc3.png")
val file = getOutputFile(File(Environment.getExternalStorageDirectory().absolutePath)
, "/output.pdf")
val fOut = FileOutputStream(file)
val document = PdfDocument()
var i = 0
imgFiles?.forEach {
i++
val bitmap = BitmapFactory.decodeFile(it?.path)
val pageInfo = PdfDocument.PageInfo.Builder(bitmap.width, bitmap.height, i).create()
val page = document.startPage(pageInfo)
val canvas = page?.canvas
val paint = Paint()
canvas?.drawPaint(paint)
paint.color = Color.BLUE;
canvas?.drawBitmap(bitmap, 0f, 0f, null)
document.finishPage(page)
bitmap.recycle()
}
document.writeTo(fOut)
document.close()
}
private fun getOutputFile(path: File, fileName: String): File? {
if (!path.exists()) {
path.mkdirs()
}
val file = File(path, fileName)
try {
if (file.exists()) {
file.delete()
}
file.createNewFile()
} catch (e: Exception) {
e.printStackTrace()
}
return file
}
}
, наконец, разрешить разрешение на хранение в манифесте, это должно работать
Что вы можете сделать, это создать еще один словарь с ключом в качестве значения других словарей, а значения этого словаря - это набор ключей этого словаря. По сути, вы возвращаете свой словарь, где ключи - это значения, а значения - это набор ключей. Поэтому, если у вас одинаковые значения, ваши ключи для этих значений будут частью этого ключа.
Вот как выглядит one_dict после преобразования:
{(('ABC', 0.4), ('ABD', 0.6)): {'A003', 'A001', 'A004'},
(('ABC', 0.5), ('ABD', 0.4), ('EFG', 0.1)): {'A002'}})
Тогда это просто вопрос итерации и печати.
from collections import defaultdict
list1 = [
{"A001": {"ABC": 0.4, "ABD": 0.6}},
{"A002": {"ABC": 0.5, "ABD": 0.4, "EFG": 0.1}},
{"A003": {"ABC": 0.4, "ABD": 0.6}},
{"A004": {"ABC": 0.4, "ABD": 0.6}},
]
one_dict = defaultdict(set)
for r in list1:
one_dict[tuple([*r.values()][0].items())].add([*r.keys()][0])
print(f"{'Account Name':<15}{'Duplicates'}")
for k, v in one_dict.items():
for i in v:
print(f"{i:<15}{', '.join(v - {i}) if 1 < len(v) else 'No duplicate'}")
Выход:
Account Name Duplicates
A001 A003, A004
A003 A001, A004
A004 A001, A003
A002 No duplicate
Элементы списка, являющиеся словарями с одной записью, делают обработку более трудоемкой, чем необходимо. Если у вас есть только одна учетная запись на элемент в списке, вы должны вместо этого сделать их кортежами (учетная запись, распределение).
преобразование List1 в этот формат (переменная allocs) делает режим кода простым:
List1 = [{'A001':{'ABC':0.4, 'ABD':0.6}}, {'A002':{'ABC':0.5, 'ABD':0.4, 'EFG':0.1}}, {'A003':{'ABC':0.4, 'ABD':0.6}}, {'A004':{'ABC':0.4, 'ABD':0.6}}]
allocs = [ list(account.items())[0] for account in List1]
for account,alloc in allocs:
dups = [ac for ac,al in allocs if al == alloc and ac != account]
print( account, ", ".join(dups or ["no duplicates"]))
A001 A003, A004
A002 no duplicates
A003 A001, A004
A004 A001, A003
Вы можете попробовать следующий фрагмент:
res = []
for idx, item in enumerate(list1):
account_name = list(item.keys())[0]
value = list1[idx][account_name]
duplicates = ", ".join([list(i.keys())[0] for i in list1 if i[list(i.keys())[0]] == value and list(i.keys())[0] != account_name])
if not duplicates:
duplicates = "No duplicates"
res.append((account_name, duplicates))