-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathdeduplicate.js
More file actions
54 lines (45 loc) · 1.42 KB
/
deduplicate.js
File metadata and controls
54 lines (45 loc) · 1.42 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
const { ethers } = require('ethers');
const fs = require('fs');
const sourceCsv = process.argv[2]
const targetCsv = process.argv[3]
if (process.argv.length !== 4) {
console.error("Must specify 2 arguments <source.csv> and <target.csv>")
process.exit(1)
}
if (!fs.existsSync(sourceCsv)) {
console.error(`Source file does not exist: ${sourceCsv}`)
process.exit(1)
}
if (fs.existsSync(targetCsv)) {
console.error(`Target file already exists: ${targetCsv}`)
process.exit(1)
}
async function readCsv() {
const fileContent = fs.readFileSync(sourceCsv).toString()
const lines = fileContent.split('\n');
const seenAddresses = new Set()
const addresses = []
let totalCount = 0;
for (let line of lines) {
line = line.trim();
if (!line) {
console.warn("Empty line when parsing CSV, skipping...")
continue
}
const [address,tokenId, amount] = line.split(',')
const checksumAddress = ethers.getAddress(address);
totalCount++;
if (seenAddresses.has(checksumAddress))
continue;
seenAddresses.add(checksumAddress)
addresses.push(address)
}
console.log(`Unique count: ${addresses.length}`)
console.log(`Total count: ${totalCount}`)
return addresses;
}
async function deduplicate() {
const addresses = await readCsv();
fs.writeFileSync(targetCsv, addresses.join('\n'))
}
deduplicate()