initBasti / Amazon2PlentySync (public) (License: GPLv3) (since 2019-01-27) (hash sha1)
Transfer your data from you Amazon Flatfile spreadsheet over to the Plentymarkets system. How to is included in the readme
List of commits:
Subject Hash Author Date (UTC)
Amazon SKU Upload 8586da2ae91d49c81a0d9b6ff220c8a1b1b011a6 Sebastian Fricke 2019-01-16 18:36:54
Inital Commit with current working version of the CLI Tool and the work in progress of the GUI. 207fef4277f7c169aa79eb39ec1aaaab258b888c Sebastian Fricke 2019-01-16 09:47:43
Initial commit ba965ee75fe09437fb08da5edd25b20e39e17eff Sebastian Fricke 2019-01-16 09:42:30
Commit 8586da2ae91d49c81a0d9b6ff220c8a1b1b011a6 - Amazon SKU Upload
Added the function for SKU upload to the CLI Client
Author: Sebastian Fricke
Author date (UTC): 2019-01-16 18:36
Committer name: Sebastian Fricke
Committer date (UTC): 2019-01-16 18:36
Parent(s): 207fef4277f7c169aa79eb39ec1aaaab258b888c
Signer:
Signing key:
Signing status: N
Tree: f515c8162a4e40fec5c728fb93341855975f7e72
File Lines added Lines deleted
Upload/sku_amazon_upload_2.csv 336 0
packages/UploadGUI.py 49 52
packages/amazon_data_upload.py 56 0
packages/item_upload.py 0 1
product_import.py 15 11
File Upload/sku_amazon_upload_2.csv added (mode: 100644) (index 0000000..57fe252)
1 VariationID;MarketID;MarketAccountID;SKU;ParentSKU
2 1639;4;0;AkaliLeggings 3/4 (1401) Black L;AkaliLeggings parent
3 1640;4;0;AkaliLeggings 3/4 (1401) Black M;AkaliLeggings parent
4 1641;4;0;AkaliLeggings 3/4 (1401) Black S;AkaliLeggings parent
5 1642;4;0;AkaliLeggings 3/4 (1401) Brown L;AkaliLeggings parent
6 1643;4;0;AkaliLeggings 3/4 (1401) Brown M;AkaliLeggings parent
7 1644;4;0;AkaliLeggings 3/4 (1401) Brown S;AkaliLeggings parent
8 1645;4;0;AkaliLeggings 3/4 (1401) Olive-green L;AkaliLeggings parent
9 1646;4;0;AkaliLeggings 3/4 (1401) Olive-green M;AkaliLeggings parent
10 1647;4;0;AkaliLeggings 3/4 (1401) Olive-green S;AkaliLeggings parent
11 1635;4;0;AkaliLeggings parent;
12 1592;4;0;BagSchultersackaLINIbeigeL;Schultersack2Size
13 1605;4;0;BagSchultersackaLINIbeigeM;Schultersack2Size
14 1595;4;0;BagSchultersackaLINIblueL;Schultersack2Size
15 1608;4;0;BagSchultersackaLINIblueM;Schultersack2Size
16 1594;4;0;BagSchultersackaLINIgrauL;Schultersack2Size
17 1607;4;0;BagSchultersackaLINIgrauM;Schultersack2Size
18 1590;4;0;BagSchultersackaLINIoliveL;Schultersack2Size
19 1603;4;0;BagSchultersackaLINIoliveM;Schultersack2Size
20 1588;4;0;BagSchultersackaLINIschwarzL;Schultersack2Size
21 1601;4;0;BagSchultersackaLINIschwarzM;Schultersack2Size
22 1636;4;0;LeggingsBatik1 parent;
23 1637;4;0;LeggingsBatik2 parent;
24 1638;4;0;LeggingsNparent;
25 1418;4;0;Schultersack2Size;
26 1419;4;0;Schultersack2Size2DesignElefant;
27 1420;4;0;Schultersack2SizeEOwebmuster;
28 1609;4;0;SchultersackD01AsanohaBlauL;Schultersack2SizeGeometrix
29 1610;4;0;SchultersackD01AsanohaBraunL;Schultersack2SizeGeometrix
30 1611;4;0;SchultersackD01AsanohaGreyL;Schultersack2SizeGeometrix
31 1612;4;0;SchultersackD01AsanohaOrangeL;Schultersack2SizeGeometrix
32 1613;4;0;SchultersackD01AsanohaSchwarzL;Schultersack2SizeGeometrix
33 1614;4;0;SchultersackD01AsanohaVioleteL;Schultersack2SizeGeometrix
34 1615;4;0;SchultersackD01AsanohaWhiteL;Schultersack2SizeGeometrix
35 1616;4;0;SchultersackD02AsanohaBlauM;Schultersack2SizeGeometrix
36 1617;4;0;SchultersackD02AsanohaBraunM;Schultersack2SizeGeometrix
37 1618;4;0;SchultersackD02AsanohaGreyM;Schultersack2SizeGeometrix
38 1619;4;0;SchultersackD02AsanohaOrangeM;Schultersack2SizeGeometrix
39 1620;4;0;SchultersackD02AsanohaSchwarzM;Schultersack2SizeGeometrix
40 1621;4;0;SchultersackD02AsanohaVioleteM;Schultersack2SizeGeometrix
41 1622;4;0;SchultersackD02AsanohaWitheM;Schultersack2SizeGeometrix
42 1623;4;0;SchultersackK01FlowerLifeGreyL;Schultersack2SizeGeometrix
43 1624;4;0;SchultersackK01FlowerLifeOrangeL;Schultersack2SizeGeometrix
44 1625;4;0;SchultersackK01FlowerLifeSchwarzL;Schultersack2SizeGeometrix
45 1626;4;0;SchultersackK01FlowerLifeWhiteL;Schultersack2SizeGeometrix
46 1627;4;0;SchultersackK02FlowerLifeGreyM;Schultersack2SizeGeometrix
47 1628;4;0;SchultersackK02FlowerLifeOrangeM;Schultersack2SizeGeometrix
48 1629;4;0;SchultersackK02FlowerLifeSchwarzM;Schultersack2SizeGeometrix
49 1630;4;0;SchultersackK02FlowerLifeWitheM;Schultersack2SizeGeometrix
50 1631;4;0;SchultersackPckBlauL;Schultersack2SizeGeometrix
51 1632;4;0;SchultersackPckBlauM;Schultersack2SizeGeometrix
52 1633;4;0;SchultersackPckSchwarzL;Schultersack2SizeGeometrix
53 1634;4;0;SchultersackPckSchwarzM;Schultersack2SizeGeometrix
54 1589;4;0;SchultersackUniBordeauxRotL;Schultersack2Size
55 1602;4;0;SchultersackUniBordeauxRotM;Schultersack2Size
56 1587;4;0;SchultersackUniDblauL;Schultersack2Size
57 1600;4;0;SchultersackUniDblauM;Schultersack2Size
58 1586;4;0;SchultersackUniGrauL;Schultersack2Size
59 1599;4;0;SchultersackUniGrauM;Schultersack2Size
60 1591;4;0;SchultersackUniOlivenGruenL;Schultersack2Size
61 1604;4;0;SchultersackUniOlivenGruenM;Schultersack2Size
62 1583;4;0;SchultersackUniRotL;Schultersack2Size
63 1596;4;0;SchultersackUniRotM;Schultersack2Size
64 1593;4;0;SchultersackUniSafronGelbL;Schultersack2Size
65 1606;4;0;SchultersackUniSafronGelbM;Schultersack2Size
66 1584;4;0;SchultersackUniSchwarzL;Schultersack2Size
67 1597;4;0;SchultersackUniSchwarzM;Schultersack2Size
68 1585;4;0;SchultersackUniWeissL;Schultersack2Size
69 1454;4;0;SchultertascheFO1muster01L;SchultertascheFOwebmuster
70 1455;4;0;SchultertascheFO1muster02L;SchultertascheFOwebmuster
71 1456;4;0;SchultertascheFO1muster03L;SchultertascheFOwebmuster
72 1457;4;0;SchultertascheFO1muster04L;SchultertascheFOwebmuster
73 1458;4;0;SchultertascheFO1muster05L;SchultertascheFOwebmuster
74 1459;4;0;SchultertascheFO1muster06L;SchultertascheFOwebmuster
75 1460;4;0;SchultertascheFO1muster07L;SchultertascheFOwebmuster
76 1461;4;0;SchultertascheFO1muster08L;SchultertascheFOwebmuster
77 1422;4;0;SchultertascheFOwebmuster;
78 1386;4;0;ShirtBen001BlackL;ShirtBen001parent
79 1387;4;0;ShirtBen001BlackM;ShirtBen001parent
80 1388;4;0;ShirtBen001BlackXL;ShirtBen001parent
81 1389;4;0;ShirtBen001BlackXXL;ShirtBen001parent
82 1390;4;0;ShirtBen001BlueL;ShirtBen001parent
83 1391;4;0;ShirtBen001BlueM;ShirtBen001parent
84 1392;4;0;ShirtBen001BlueXL;ShirtBen001parent
85 1393;4;0;ShirtBen001BlueXXL;ShirtBen001parent
86 1291;4;0;ShirtBen001HEMPparent;
87 1326;4;0;ShirtBen001HempBlackL;ShirtBen001HEMPparent
88 1327;4;0;ShirtBen001HempBlackL_Longsleeve;ShirtBen001HEMPparent
89 1328;4;0;ShirtBen001HempBlackM;ShirtBen001HEMPparent
90 1329;4;0;ShirtBen001HempBlackM_Longsleeve;ShirtBen001HEMPparent
91 1330;4;0;ShirtBen001HempBlackXL;ShirtBen001HEMPparent
92 1331;4;0;ShirtBen001HempBlackXL_Longsleeve;ShirtBen001HEMPparent
93 1332;4;0;ShirtBen001HempBlackXXL;ShirtBen001HEMPparent
94 1333;4;0;ShirtBen001HempBlackXXL_Longsleeve;ShirtBen001HEMPparent
95 1334;4;0;ShirtBen001HempCreamWhiteL;ShirtBen001HEMPparent
96 1335;4;0;ShirtBen001HempCreamWhiteL_Longsleeve;ShirtBen001HEMPparent
97 1336;4;0;ShirtBen001HempCreamWhiteM;ShirtBen001HEMPparent
98 1337;4;0;ShirtBen001HempCreamWhiteM_Longsleeve;ShirtBen001HEMPparent
99 1338;4;0;ShirtBen001HempCreamWhiteXL;ShirtBen001HEMPparent
100 1339;4;0;ShirtBen001HempCreamWhiteXL_Longsleeve;ShirtBen001HEMPparent
101 1340;4;0;ShirtBen001HempCreamWhiteXXL;ShirtBen001HEMPparent
102 1341;4;0;ShirtBen001HempCreamWhiteXXL_Longsleeve;ShirtBen001HEMPparent
103 1342;4;0;ShirtBen001HempWeissL;ShirtBen001HEMPparent
104 1343;4;0;ShirtBen001HempWeissL_Longsleeve;ShirtBen001HEMPparent
105 1344;4;0;ShirtBen001HempWeissM;ShirtBen001HEMPparent
106 1345;4;0;ShirtBen001HempWeissM_Longsleeve;ShirtBen001HEMPparent
107 1346;4;0;ShirtBen001HempWeissXL;ShirtBen001HEMPparent
108 1347;4;0;ShirtBen001HempWeissXL_Longsleeve;ShirtBen001HEMPparent
109 1348;4;0;ShirtBen001HempWeissXXL;ShirtBen001HEMPparent
110 1349;4;0;ShirtBen001HempWeissXXL_Longsleeve;ShirtBen001HEMPparent
111 1394;4;0;ShirtBen001NaturL;ShirtBen001parent
112 1395;4;0;ShirtBen001NaturM;ShirtBen001parent
113 1396;4;0;ShirtBen001NaturXL;ShirtBen001parent
114 1397;4;0;ShirtBen001NaturXXL;ShirtBen001parent
115 1398;4;0;ShirtBen001WeissL;ShirtBen001parent
116 1399;4;0;ShirtBen001WeissM;ShirtBen001parent
117 1400;4;0;ShirtBen001WeissXL;ShirtBen001parent
118 1401;4;0;ShirtBen001WeissXXL;ShirtBen001parent
119 1292;4;0;ShirtBen001parent;
120 1402;4;0;ShirtBen002BlackL_longsleeve;ShirtBen001parent
121 1403;4;0;ShirtBen002BlackM_longsleeve;ShirtBen001parent
122 1404;4;0;ShirtBen002BlackXL_longsleeve;ShirtBen001parent
123 1405;4;0;ShirtBen002BlackXXL_longsleeve;ShirtBen001parent
124 1406;4;0;ShirtBen002BlueL_longsleeve;ShirtBen001parent
125 1407;4;0;ShirtBen002BlueM_longsleeve;ShirtBen001parent
126 1408;4;0;ShirtBen002BlueXL_longsleeve;ShirtBen001parent
127 1409;4;0;ShirtBen002BlueXXL_longsleeve;ShirtBen001parent
128 1410;4;0;ShirtBen002NaturL_longsleeve;ShirtBen001parent
129 1411;4;0;ShirtBen002NaturM_longsleeve;ShirtBen001parent
130 1412;4;0;ShirtBen002NaturXL_longsleeve;ShirtBen001parent
131 1413;4;0;ShirtBen002NaturXXL_longsleeve;ShirtBen001parent
132 1414;4;0;ShirtBen002WeissL_longsleeve;ShirtBen001parent
133 1415;4;0;ShirtBen002WeissM_longsleeve;ShirtBen001parent
134 1416;4;0;ShirtBen002WeissXL_longsleeve;ShirtBen001parent
135 1417;4;0;ShirtBen002WeissXXL_longsleeve;ShirtBen001parent
136 1462;4;0;ShirtRZI01buttonBlackL;ShirtRZI01buttonParent
137 1463;4;0;ShirtRZI01buttonBlackL_longsleeve;ShirtRZI01buttonParent
138 1464;4;0;ShirtRZI01buttonBlackM;ShirtRZI01buttonParent
139 1465;4;0;ShirtRZI01buttonBlackM_longsleeve;ShirtRZI01buttonParent
140 1466;4;0;ShirtRZI01buttonBlackXL;ShirtRZI01buttonParent
141 1467;4;0;ShirtRZI01buttonBlackXL_longsleeve;ShirtRZI01buttonParent
142 1468;4;0;ShirtRZI01buttonBlackXXL;ShirtRZI01buttonParent
143 1469;4;0;ShirtRZI01buttonBlackXXL_longsleeve;ShirtRZI01buttonParent
144 1470;4;0;ShirtRZI01buttonBlackXXXL;ShirtRZI01buttonParent
145 1471;4;0;ShirtRZI01buttonBlackXXXL_longsleeve;ShirtRZI01buttonParent
146 1472;4;0;ShirtRZI01buttonNaturL;ShirtRZI01buttonParent
147 1473;4;0;ShirtRZI01buttonNaturL_longsleeve;ShirtRZI01buttonParent
148 1474;4;0;ShirtRZI01buttonNaturM;ShirtRZI01buttonParent
149 1475;4;0;ShirtRZI01buttonNaturM_longsleeve;ShirtRZI01buttonParent
150 1476;4;0;ShirtRZI01buttonNaturXL;ShirtRZI01buttonParent
151 1477;4;0;ShirtRZI01buttonNaturXL_longsleeve;ShirtRZI01buttonParent
152 1478;4;0;ShirtRZI01buttonNaturXXL;ShirtRZI01buttonParent
153 1479;4;0;ShirtRZI01buttonNaturXXL_longsleeve;ShirtRZI01buttonParent
154 1480;4;0;ShirtRZI01buttonNaturXXXL;ShirtRZI01buttonParent
155 1481;4;0;ShirtRZI01buttonNaturXXXL_longsleeve;ShirtRZI01buttonParent
156 1423;4;0;ShirtRZI01buttonParent;
157 1482;4;0;ShirtRZI01buttonWeissL;ShirtRZI01buttonParent
158 1483;4;0;ShirtRZI01buttonWeissL_longsleeve;ShirtRZI01buttonParent
159 1484;4;0;ShirtRZI01buttonWeissM;ShirtRZI01buttonParent
160 1485;4;0;ShirtRZI01buttonWeissM_longsleeve;ShirtRZI01buttonParent
161 1486;4;0;ShirtRZI01buttonWeissXL;ShirtRZI01buttonParent
162 1487;4;0;ShirtRZI01buttonWeissXL_longsleeve;ShirtRZI01buttonParent
163 1488;4;0;ShirtRZI01buttonWeissXXL;ShirtRZI01buttonParent
164 1489;4;0;ShirtRZI01buttonWeissXXL_longsleeve;ShirtRZI01buttonParent
165 1490;4;0;ShirtRZI01buttonWeissXXXL;ShirtRZI01buttonParent
166 1491;4;0;ShirtRZI01buttonWeissXXXL_longsleeve;ShirtRZI01buttonParent
167 1492;4;0;ShirtRZI02ButtonfreeBlackL;ShirtRZI02ButtonfreeParent
168 1493;4;0;ShirtRZI02ButtonfreeBlackM;ShirtRZI02ButtonfreeParent
169 1494;4;0;ShirtRZI02ButtonfreeBlackXL;ShirtRZI02ButtonfreeParent
170 1495;4;0;ShirtRZI02ButtonfreeBlackXXL;ShirtRZI02ButtonfreeParent
171 1496;4;0;ShirtRZI02ButtonfreeBlackXXXL;ShirtRZI02ButtonfreeParent
172 1424;4;0;ShirtRZI02ButtonfreeParent;
173 1497;4;0;ShirtRZI02ButtonfreeWeissL;ShirtRZI02ButtonfreeParent
174 1498;4;0;ShirtRZI02ButtonfreeWeissM;ShirtRZI02ButtonfreeParent
175 1499;4;0;ShirtRZI02ButtonfreeWeissXL;ShirtRZI02ButtonfreeParent
176 1500;4;0;ShirtRZI02ButtonfreeWeissXXL;ShirtRZI02ButtonfreeParent
177 1501;4;0;ShirtRZI02ButtonfreeWeissXXXL;ShirtRZI02ButtonfreeParent
178 1366;4;0;Shirt_H01_Beige_L;Shirt_H01_Parent
179 1367;4;0;Shirt_H01_Beige_M;Shirt_H01_Parent
180 1368;4;0;Shirt_H01_Beige_XL;Shirt_H01_Parent
181 1369;4;0;Shirt_H01_Beige_XXL;Shirt_H01_Parent
182 1370;4;0;Shirt_H01_Blue_L;Shirt_H01_Parent
183 1371;4;0;Shirt_H01_Blue_M;Shirt_H01_Parent
184 1372;4;0;Shirt_H01_Blue_XL;Shirt_H01_Parent
185 1373;4;0;Shirt_H01_Blue_XXL;Shirt_H01_Parent
186 1374;4;0;Shirt_H01_Grey_L;Shirt_H01_Parent
187 1375;4;0;Shirt_H01_Grey_M;Shirt_H01_Parent
188 1376;4;0;Shirt_H01_Grey_XL;Shirt_H01_Parent
189 1377;4;0;Shirt_H01_Grey_XXL;Shirt_H01_Parent
190 1378;4;0;Shirt_H01_Nature-white_L;Shirt_H01_Parent
191 1379;4;0;Shirt_H01_Nature-white_M;Shirt_H01_Parent
192 1380;4;0;Shirt_H01_Nature-white_XL;Shirt_H01_Parent
193 1381;4;0;Shirt_H01_Nature-white_XXL;Shirt_H01_Parent
194 1382;4;0;Shirt_H01_Olive-green_L;Shirt_H01_Parent
195 1383;4;0;Shirt_H01_Olive-green_M;Shirt_H01_Parent
196 1384;4;0;Shirt_H01_Olive-green_XL;Shirt_H01_Parent
197 1385;4;0;Shirt_H01_Olive-green_XXL;Shirt_H01_Parent
198 1293;4;0;Shirt_H01_Parent;
199 1502;4;0;Shirt_T01_Black_L;Shirt_T01_parent
200 1503;4;0;Shirt_T01_Black_M;Shirt_T01_parent
201 1504;4;0;Shirt_T01_Black_XL;Shirt_T01_parent
202 1505;4;0;Shirt_T01_Black_XXL;Shirt_T01_parent
203 1506;4;0;Shirt_T01_Blue_L;Shirt_T01_parent
204 1507;4;0;Shirt_T01_Blue_M;Shirt_T01_parent
205 1508;4;0;Shirt_T01_Blue_XL;Shirt_T01_parent
206 1509;4;0;Shirt_T01_Blue_XXL;Shirt_T01_parent
207 1510;4;0;Shirt_T01_Brown_L;Shirt_T01_parent
208 1511;4;0;Shirt_T01_Brown_M;Shirt_T01_parent
209 1512;4;0;Shirt_T01_Brown_XL;Shirt_T01_parent
210 1513;4;0;Shirt_T01_Brown_XXL;Shirt_T01_parent
211 1514;4;0;Shirt_T01_Natural-white_L;Shirt_T01_parent
212 1515;4;0;Shirt_T01_Natural-white_M;Shirt_T01_parent
213 1516;4;0;Shirt_T01_Natural-white_XL;Shirt_T01_parent
214 1517;4;0;Shirt_T01_Natural-white_XXL;Shirt_T01_parent
215 1518;4;0;Shirt_T01_White_L;Shirt_T01_parent
216 1519;4;0;Shirt_T01_White_M;Shirt_T01_parent
217 1520;4;0;Shirt_T01_White_XL;Shirt_T01_parent
218 1521;4;0;Shirt_T01_White_XXL;Shirt_T01_parent
219 1425;4;0;Shirt_T01_parent;
220 1522;4;0;ShoulderBagBO1elefantCreamL;Schultersack2Size2DesignElefant
221 1523;4;0;ShoulderBagBO1elefantDblauL;Schultersack2Size2DesignElefant
222 1524;4;0;ShoulderBagBO1elefantGoldgelbL;Schultersack2Size2DesignElefant
223 1525;4;0;ShoulderBagBO1elefantGraublauL;Schultersack2Size2DesignElefant
224 1526;4;0;ShoulderBagBO1elefantSchwarzL;Schultersack2Size2DesignElefant
225 1527;4;0;ShoulderBagBO2elefantCreamM;Schultersack2Size2DesignElefant
226 1528;4;0;ShoulderBagBO2elefantDblauM;Schultersack2Size2DesignElefant
227 1529;4;0;ShoulderBagBO2elefantGoldgelbM;Schultersack2Size2DesignElefant
228 1530;4;0;ShoulderBagBO2elefantGraublauM;Schultersack2Size2DesignElefant
229 1531;4;0;ShoulderBagBO2elefantSchwarzM;Schultersack2Size2DesignElefant
230 1532;4;0;ShoulderBagCO1elefantGrauL;Schultersack2Size2DesignElefant
231 1533;4;0;ShoulderBagCO1elefantGraublaupinkL;Schultersack2Size2DesignElefant
232 1534;4;0;ShoulderBagCO1elefantGreenL;Schultersack2Size2DesignElefant
233 1535;4;0;ShoulderBagCO1elefantLightGreenL;Schultersack2Size2DesignElefant
234 1536;4;0;ShoulderBagCO1elefantLilatonL;Schultersack2Size2DesignElefant
235 1537;4;0;ShoulderBagCO1elefantOrange2L;Schultersack2Size2DesignElefant
236 1538;4;0;ShoulderBagCO1elefantOrangeL;Schultersack2Size2DesignElefant
237 1539;4;0;ShoulderBagCO1elefantWeinrotGrauL;Schultersack2Size2DesignElefant
238 1540;4;0;ShoulderBagCO2elefantBeigeM;Schultersack2Size2DesignElefant
239 1541;4;0;ShoulderBagCO2elefantGraublaupinkM;Schultersack2Size2DesignElefant
240 1542;4;0;ShoulderBagCO2elefantGreenM;Schultersack2Size2DesignElefant
241 1543;4;0;ShoulderBagCO2elefantLightGreenM;Schultersack2Size2DesignElefant
242 1544;4;0;ShoulderBagCO2elefantLilaM;Schultersack2Size2DesignElefant
243 1545;4;0;ShoulderBagCO2elefantOrange2M;Schultersack2Size2DesignElefant
244 1546;4;0;ShoulderBagCO2elefantOrangeM;Schultersack2Size2DesignElefant
245 1547;4;0;ShoulderBagCO2elefantWeinrotgrauM;Schultersack2Size2DesignElefant
246 1548;4;0;ShoulderBagEO1muster01L;Schultersack2SizeEOwebmuster
247 1549;4;0;ShoulderBagEO1muster02L;Schultersack2SizeEOwebmuster
248 1550;4;0;ShoulderBagEO1muster03L;Schultersack2SizeEOwebmuster
249 1551;4;0;ShoulderBagEO1muster04L;Schultersack2SizeEOwebmuster
250 1552;4;0;ShoulderBagEO1muster05L;Schultersack2SizeEOwebmuster
251 1553;4;0;ShoulderBagEO1muster06L;Schultersack2SizeEOwebmuster
252 1554;4;0;ShoulderBagEO1muster07L;Schultersack2SizeEOwebmuster
253 1555;4;0;ShoulderBagEO1muster09L;Schultersack2SizeEOwebmuster
254 1556;4;0;ShoulderBagEO2muster01M;Schultersack2SizeEOwebmuster
255 1557;4;0;ShoulderBagEO2muster02M;Schultersack2SizeEOwebmuster
256 1558;4;0;ShoulderBagEO2muster03M;Schultersack2SizeEOwebmuster
257 1559;4;0;ShoulderBagEO2muster04M;Schultersack2SizeEOwebmuster
258 1560;4;0;ShoulderBagEO2muster05M;Schultersack2SizeEOwebmuster
259 1561;4;0;ShoulderBagEO2muster06M;Schultersack2SizeEOwebmuster
260 1562;4;0;ShoulderBagEO2muster07M;Schultersack2SizeEOwebmuster
261 1563;4;0;ShoulderBagEO2muster09M;Schultersack2SizeEOwebmuster
262 1564;4;0;ShoulderBagWOV22_L(E01);Schultersack2SizeEOwebmuster
263 1565;4;0;ShoulderBagWOV22_M(E02);Schultersack2SizeEOwebmuster
264 1566;4;0;ShoulderBagWOV23_L(E01);Schultersack2SizeEOwebmuster
265 1567;4;0;ShoulderBagWOV23_M(E02);Schultersack2SizeEOwebmuster
266 1568;4;0;ShoulderBagWOV24_L(E01);Schultersack2SizeEOwebmuster
267 1569;4;0;ShoulderBagWOV24_M(E02);Schultersack2SizeEOwebmuster
268 1570;4;0;ShoulderBagWOV25_L(E01);Schultersack2SizeEOwebmuster
269 1571;4;0;ShoulderBagWOV25_M(E02);Schultersack2SizeEOwebmuster
270 1572;4;0;ShoulderBagWOV26_L(E01);Schultersack2SizeEOwebmuster
271 1573;4;0;ShoulderBagWOV26_M(E02);Schultersack2SizeEOwebmuster
272 1574;4;0;ShoulderBagWOV27_L(E01);Schultersack2SizeEOwebmuster
273 1575;4;0;ShoulderBagWOV27_M(E02);Schultersack2SizeEOwebmuster
274 1576;4;0;ShoulderBagWOV28_L(E01);Schultersack2SizeEOwebmuster
275 1577;4;0;ShoulderBagWOV28_M(E02);Schultersack2SizeEOwebmuster
276 1578;4;0;ShoulderBagWOV29_L(E01);Schultersack2SizeEOwebmuster
277 1579;4;0;ShoulderBagWOV29_M(E02);Schultersack2SizeEOwebmuster
278 1580;4;0;ShoulderBagWOV30_L(E01);Schultersack2SizeEOwebmuster
279 1581;4;0;ShoulderBagWOV31_L(E01);Schultersack2SizeEOwebmuster
280 1582;4;0;ShoulderBagWOV32_M(E02);Schultersack2SizeEOwebmuster
281 1648;4;0;TrLeggingsBatik2BuntTydy02;LeggingsBatik2 parent
282 1649;4;0;TrLeggingsBatik2BuntTydy03;LeggingsBatik2 parent
283 1650;4;0;TrLeggingsBatik2BuntTydyBlau;LeggingsBatik2 parent
284 1651;4;0;TrLeggingsBatik2BuntTydyBraungelb;LeggingsBatik2 parent
285 1652;4;0;TrLeggingsBatik2BuntTzdz;LeggingsBatik2 parent
286 1653;4;0;TrLeggingsBatik2Buntlevel;LeggingsBatik2 parent
287 1654;4;0;TrLeggingsBatik2Buntlevel02;LeggingsBatik2 parent
288 1655;4;0;TrLeggingsBatik2Circle01Lilaton;LeggingsBatik2 parent
289 1656;4;0;TrLeggingsBatik2Circle02Dlilaton;LeggingsBatik2 parent
290 1657;4;0;TrLeggingsBatik2Circle03Blauton;LeggingsBatik2 parent
291 1658;4;0;TrLeggingsBatik2Circle04Oliventon;LeggingsBatik2 parent
292 1659;4;0;TrLeggingsBatik2Circle05BlackBrown;LeggingsBatik2 parent
293 1660;4;0;TrLeggingsBatik2Dunkelgruen;LeggingsBatik2 parent
294 1661;4;0;TrLeggingsBatik2MarmorWeiss;LeggingsBatik2 parent
295 1662;4;0;TrLeggingsBatik2Pink;LeggingsBatik2 parent
296 1663;4;0;TrLeggingsBatik2Tydy04green;LeggingsBatik2 parent
297 1664;4;0;TrLeggingsBatik2Tydy05beige;LeggingsBatik2 parent
298 1665;4;0;TrLeggingsBatik2Tydy06purple;LeggingsBatik2 parent
299 1666;4;0;TrLeggingsBatik2Tydy07redbrown;LeggingsBatik2 parent
300 1667;4;0;TrLeggingsBatik2Tydy10Lilaton;LeggingsBatik2 parent
301 1668;4;0;TrLeggingsBatik2Tydy11Braunton;LeggingsBatik2 parent
302 1669;4;0;TrLeggingsBatik2Tydy12Blauton;LeggingsBatik2 parent
303 1670;4;0;TrLeggingsBatik2Tydy13Blaubunt;LeggingsBatik2 parent
304 1671;4;0;TrLeggingsBatik2Tydy14olive;LeggingsBatik2 parent
305 1672;4;0;TrLeggingsBatik2Tydy15purple;LeggingsBatik2 parent
306 1673;4;0;TrLeggingsBatik2Tydy16blau;LeggingsBatik2 parent
307 1674;4;0;TrLeggingsBatik2tzdz08turkis;LeggingsBatik2 parent
308 1675;4;0;TrLeggingsBatik2tzdz09braunton;LeggingsBatik2 parent
309 1676;4;0;TrLeggingsBatikCT01Gruenton;LeggingsBatik1 parent
310 1677;4;0;TrLeggingsBatikCT02Lilaton;LeggingsBatik1 parent
311 1678;4;0;TrLeggingsBatikCT03Blauton;LeggingsBatik1 parent
312 1679;4;0;TrLeggingsBatikCT04Lilaton;LeggingsBatik1 parent
313 1680;4;0;TrLeggingsBatikCT05Braunton;LeggingsBatik1 parent
314 1681;4;0;TrLeggingsBatikDgruen;LeggingsBatik1 parent
315 1682;4;0;TrLeggingsBatikJeansBlau;LeggingsBatik1 parent
316 1683;4;0;TrLeggingsBatikLila;LeggingsBatik1 parent
317 1684;4;0;TrLeggingsBatikLila2;LeggingsBatik1 parent
318 1685;4;0;TrLeggingsBatikNavyBlau;LeggingsBatik1 parent
319 1686;4;0;TrLeggingsBatikSchwarz;LeggingsBatik1 parent
320 1687;4;0;TrLeggingsBatikTH01BlackPurple;LeggingsBatik1 parent
321 1688;4;0;TrLeggingsBatikTH02Black;LeggingsBatik1 parent
322 1689;4;0;TrLeggingsN001_Pants;LeggingsNparent
323 1690;4;0;TrLeggingsN002_Pants;LeggingsNparent
324 1691;4;0;TrLeggingsN003_Pants;LeggingsNparent
325 1692;4;0;TrLeggingsN004_Pants_brown;LeggingsNparent
326 1693;4;0;TrLeggingsN005_Pants;LeggingsNparent
327 1694;4;0;TrLeggingsN006_Pants;LeggingsNparent
328 1695;4;0;TrLeggingsN007_Pants;LeggingsNparent
329 1696;4;0;TrLeggingsN008_Pants;LeggingsNparent
330 1697;4;0;TrLeggingsN009_Pants;LeggingsNparent
331 1698;4;0;TrLeggingsN010_Pants;LeggingsNparent
332 1699;4;0;TrLeggingsN011_Pants;LeggingsNparent
333 1700;4;0;TrLeggingsU001_Pants;LeggingsNparent
334 1701;4;0;TrLeggingsU002_Pants;LeggingsNparent
335 1702;4;0;TrLeggingsU003_Pants;LeggingsNparent
336 1703;4;0;TrLeggingsU004_Pants;LeggingsNparent
File packages/UploadGUI.py changed (mode: 100644) (index 91249c7..f45f127)
1 1 import tkinter import tkinter
2 2 from os.path import isfile from os.path import isfile
3 3
4 #class checkBoxes(tkinter.Frame):
5 #def __init__(self, master,
6
4 # class checkBoxes(tkinter.Frame):
5 # def __init__(self, master,
7 6
8 7
9 8 class UploadGUI(tkinter.Tk): class UploadGUI(tkinter.Tk):
 
... ... class UploadGUI(tkinter.Tk):
11 10 tkinter.Tk.__init__(self, master) tkinter.Tk.__init__(self, master)
12 11 self.master = master self.master = master
13 12 self.initialize() self.initialize()
14
15
13
16 14 def initialize(self): def initialize(self):
17 15 self.grid() self.grid()
18
16
19 17 self.bg = "chocolate1" self.bg = "chocolate1"
20 18 self.txtcolor = "black" self.txtcolor = "black"
21 19 self.bordercolor = "red4" self.bordercolor = "red4"
22 20 if(isfile('/home/basti/Documents/PyProjects/CSV-Project/PlentyMarkets/packages/gfx/checkbox-unchecked.png')): if(isfile('/home/basti/Documents/PyProjects/CSV-Project/PlentyMarkets/packages/gfx/checkbox-unchecked.png')):
23 self.uncheckedimg = tkinter.PhotoImage(file='/home/basti/Documents/PyProjects/CSV-Project/PlentyMarkets/packages/gfx/checkbox-unchecked.png')
21 self.uncheckedimg = tkinter.PhotoImage(
22 file='/home/basti/Documents/PyProjects/CSV-Project/PlentyMarkets/packages/gfx/checkbox-unchecked.png')
24 23 print("OK img1") print("OK img1")
25 24 if(isfile('/home/basti/Documents/PyProjects/CSV-Project/PlentyMarkets/packages/gfx/checkbox-checked.png')): if(isfile('/home/basti/Documents/PyProjects/CSV-Project/PlentyMarkets/packages/gfx/checkbox-checked.png')):
26 self.checkedimg = tkinter.PhotoImage(file='/home/basti/Documents/PyProjects/CSV-Project/PlentyMarkets/packages/gfx/checkbox-checked.png')
25 self.checkedimg = tkinter.PhotoImage(
26 file='/home/basti/Documents/PyProjects/CSV-Project/PlentyMarkets/packages/gfx/checkbox-checked.png')
27 27 print("OK img2") print("OK img2")
28
28
29 29 self.header = tkinter.Label(self, text="Choose which upload files you want to create and upload the required files.\n", self.header = tkinter.Label(self, text="Choose which upload files you want to create and upload the required files.\n",
30 anchor="w",fg=self.txtcolor,bg=self.bg)
30 anchor="w", fg=self.txtcolor, bg=self.bg)
31 31 self.header.grid(column=0, row=0, columnspan=5, rowspan=2, sticky="EW") self.header.grid(column=0, row=0, columnspan=5, rowspan=2, sticky="EW")
32
33
32
34 33 self.itemup_desc = tkinter.Label(self, text="Item Upload(Parent)\t", self.itemup_desc = tkinter.Label(self, text="Item Upload(Parent)\t",
35 34 anchor="center", fg=self.txtcolor, bg=self.bg) anchor="center", fg=self.txtcolor, bg=self.bg)
36 35 self.itemup_desc.grid(column=0, row=3, sticky="EW") self.itemup_desc.grid(column=0, row=3, sticky="EW")
37
38 self.variationup_desc = tkinter.Label(self, text="Variation Upload(children)\t",
39 anchor="center", fg=self.txtcolor, bg=self.bg)
36
37 self.variationup_desc = tkinter.Label(
38 self, text="Variation Upload\t", anchor="center", fg=self.txtcolor, bg=self.bg)
40 39 self.variationup_desc.grid(column=1, row=3, sticky="EW") self.variationup_desc.grid(column=1, row=3, sticky="EW")
41
40
42 41 self.activeup_desc = tkinter.Label(self, text="variation status to active\t", self.activeup_desc = tkinter.Label(self, text="variation status to active\t",
43 anchor="center", fg=self.txtcolor, bg=self.bg)
42 anchor="center", fg=self.txtcolor, bg=self.bg)
44 43 self.activeup_desc.grid(column=2, row=3, sticky="EW") self.activeup_desc.grid(column=2, row=3, sticky="EW")
45
44
46 45 self.barcodeup_desc = tkinter.Label(self, text="barcode Upload\t", self.barcodeup_desc = tkinter.Label(self, text="barcode Upload\t",
47 anchor="center", fg=self.txtcolor, bg=self.bg)
48 self.barcodeup_desc.grid(column=3, row=3, sticky="EW")
49
50 #Trying to use a canvas as a checkbox for cosmetic reasons
46 anchor="center", fg=self.txtcolor, bg=self.bg)
47 self.barcodeup_desc.grid(column=3, row=3, sticky="EW")
48
49 # Trying to use a canvas as a checkbox for cosmetic reasons
51 50 #========================================================= #=========================================================
52
53 #self.itemup_check = tkinter.Canvas(width=150,height=40,bg=self.bg
54 #, bd=0, highlightthickness=0)
51
52 # self.itemup_check = tkinter.Canvas(width=150,height=40,bg=self.bg
53 #, bd=0, highlightthickness=0)
55 54 #self.itemup_check.bind("<Button-1>", lambda event, item = self.itemup_check, check = self.item_state, image1 = self.uncheckedimg, image2 = self.checkedimg : self.switchImage(item, check, image1, image2)) #self.itemup_check.bind("<Button-1>", lambda event, item = self.itemup_check, check = self.item_state, image1 = self.uncheckedimg, image2 = self.checkedimg : self.switchImage(item, check, image1, image2))
56 #self.itemup_check.create_image(0,0,image=self.uncheckedimg,anchor="nw")
55 # self.itemup_check.create_image(0,0,image=self.uncheckedimg,anchor="nw")
57 56 #self.itemup_check.grid(column=0, row=4,sticky="EW") #self.itemup_check.grid(column=0, row=4,sticky="EW")
58
59 #self.variationup_check = tkinter.Canvas(width=150,height=40,bg=self.bg
60 #, bd=0, highlightthickness=0)
61 #self.variationup_check.bind("<Button-1>", )
62 #self.variationup_check.create_image(0,0,image=self.uncheckedimg,anchor="nw")
57
58 # self.variationup_check = tkinter.Canvas(width=150,height=40,bg=self.bg
59 #, bd=0, highlightthickness=0)
60 #self.variationup_check.bind("<Button-1>", )
61 # self.variationup_check.create_image(0,0,image=self.uncheckedimg,anchor="nw")
63 62 #self.variationup_check.grid(column=1, row=4,sticky="EW") #self.variationup_check.grid(column=1, row=4,sticky="EW")
64 63
65 #self.active_check = tkinter.Canvas(width=150,height=40,bg=self.bg
66 #, bd=0, highlightthickness=0)
67 #self.active_check.bind("<Button-1>", )
68 #self.active_check.create_image(0,0,image=self.uncheckedimg,anchor="nw")
69 #self.active_check.grid(column=2, row=4,sticky="EW")
70
71 #self.barcodeup_check = tkinter.Canvas(width=150,height=40,bg=self.bg
72 #, bd=0, highlightthickness=0)
73 #self.barcodeup_check.bind("<Button-1>", )
74 #self.barcodeup_check.create_image(0,0,image=self.uncheckedimg,anchor="nw")
75 #self.barcodeup_check.grid(column=3, row=4,sticky="EW")
76
77
78 #def switchImage(self, element, check, image1, image2):
79 #for state in [self.item_state, self.variation_state, self.active_state, self.barcode_state]:
80 #if(id(check) == id(state)):
81 #if(state):
82 #element.create_image(0,0,image=image1,anchor="nw")
83 #else:
84 #element.create_image(0,0,image=image2,anchor="nw")
85
64 # self.active_check = tkinter.Canvas(width=150,height=40,bg=self.bg
65 #, bd=0, highlightthickness=0)
66 #self.active_check.bind("<Button-1>", )
67 # self.active_check.create_image(0,0,image=self.uncheckedimg,anchor="nw")
68 #self.active_check.grid(column=2, row=4,sticky="EW")
69
70 # self.barcodeup_check = tkinter.Canvas(width=150,height=40,bg=self.bg
71 #, bd=0, highlightthickness=0)
72 #self.barcodeup_check.bind("<Button-1>", )
73 # self.barcodeup_check.create_image(0,0,image=self.uncheckedimg,anchor="nw")
74 #self.barcodeup_check.grid(column=3, row=4,sticky="EW")
75
76 # def switchImage(self, element, check, image1, image2):
77 # for state in [self.item_state, self.variation_state, self.active_state, self.barcode_state]:
78 # if(id(check) == id(state)):
79 # if(state):
80 # element.create_image(0,0,image=image1,anchor="nw")
81 # else:
82 # element.create_image(0,0,image=image2,anchor="nw")
File packages/amazon_data_upload.py added (mode: 100644) (index 0000000..f636f7a)
1 import csv
2 from os.path import isfile
3 import sys
4 try:
5 from sortedcontainers import SortedDict
6 except ImportError:
7 print("the sortedcontainers module is required to run this program.")
8 raise ImportError
9
10
11 def writeCSV(dataobject, name, columns):
12 '''Write Data into new CSV for Upload
13 OUTPUT
14 '''
15
16 output_path_number = 1
17 datatype = ".csv"
18 output_path = "Upload/" + name + "_upload_" + str(output_path_number) + datatype
19
20 while(isfile(output_path)):
21 output_path_number = int(output_path_number) + 1
22 output_path = "Upload/" + name + "_upload_" + str(output_path_number) + datatype
23
24 with open(output_path, mode='a') as item:
25 writer = csv.DictWriter(item, delimiter=";", fieldnames=columns)
26 writer.writeheader()
27 for row in dataobject:
28 writer.writerow(dataobject[row])
29
30 if(isfile(output_path)):
31 print("Upload file successfully created under {0}".format(output_path))
32
33 return output_path
34
35
36 def amazon_sku_upload(flatfile, export):
37
38 column_names=['VariationID','MarketID','MarketAccountID','SKU','ParentSKU']
39 Data = SortedDict()
40
41 with open(export, mode='r') as item:
42 reader = csv.DictReader(item, delimiter=';')
43 item_number = 1
44 for row in reader:
45 if(row['VariationID']):
46 values=[row['VariationID'],'4','0','','']
47 Data[row['VariationNumber']]=SortedDict(zip(column_names,values))
48
49 with open(flatfile, mode='r') as item:
50 reader = csv.DictReader(item, delimiter=';')
51 for row in reader:
52 if(row['item_sku'] in [*Data]):
53 Data[row['item_sku']]['SKU'] = row['item_sku']
54 Data[row['item_sku']]['ParentSKU'] = row['parent_sku']
55
56 output_path = writeCSV(Data, 'sku_amazon', column_names)
File packages/item_upload.py changed (mode: 100644) (index f0872a2..97541ce)
... ... try:
6 6 except ImportError: except ImportError:
7 7 print("the sortedcontainers module is required to run this program.") print("the sortedcontainers module is required to run this program.")
8 8 raise ImportError raise ImportError
9 #from ..packages.category import determineCategory
10 9
11 10
12 11 def itemUpload(filepath, intern_number): def itemUpload(filepath, intern_number):
File product_import.py changed (mode: 100644) (index 030778f..33f0620)
... ... from packages.attribute_upload import attributeUpload
6 6 from packages.variation_upload import variationUpload, setActive, EANUpload from packages.variation_upload import variationUpload, setActive, EANUpload
7 7 from packages.stock_upload import stockUpload, priceUpload from packages.stock_upload import stockUpload, priceUpload
8 8 from packages.UploadGUI import UploadGUI from packages.UploadGUI import UploadGUI
9 from packages.amazon_data_upload import amazon_sku_upload
9 10
10 11
11 12 def main(): def main():
 
... ... def main():
22 23 print("spreadsheet csv containing the flatfile : ", sheet) print("spreadsheet csv containing the flatfile : ", sheet)
23 24 print("spreadsheet csv containing the intern numbers : ", intern_number) print("spreadsheet csv containing the intern numbers : ", intern_number)
24 25 try: try:
25 itempath = itemUpload(sheet, intern_number)
26 print("Item Upload")
27 # itempath = itemUpload(sheet, intern_number)
26 28 except Exception as exc: except Exception as exc:
27 29 print(exc) print(exc)
28 30 print("Item Upload failed!") print("Item Upload failed!")
29 31
30 32 try: try:
31 variationpath = variationUpload(sheet, intern_number)
33 print("Variation Upload")
34 # variationpath = variationUpload(sheet, intern_number)
32 35 except Exception as exc: except Exception as exc:
33 36 print(exc) print(exc)
34 37 print("VariationUpload failed!") print("VariationUpload failed!")
 
... ... def main():
43 46 print("Something went wrong at the Export file import!") print("Something went wrong at the Export file import!")
44 47 print("spreadsheet csv containing the export : ", export) print("spreadsheet csv containing the export : ", export)
45 48 try: try:
46 EANUpload(sheet, export)
47 setActive(sheet, export)
48 priceUpload(sheet, export)
49 print("EAN, Active & Price Upload")
50 # EANUpload(sheet, export)
51 # setActive(sheet, export)
52 # priceUpload(sheet, export)
49 53 except FileNotFoundError as err: except FileNotFoundError as err:
50 54 print(err) print(err)
51 55 print("Missing Data, check if you have\n - a flatfile\n - a intern file table\n - export file from plentymarkets\n - a sheet with the stock numbers!\n") print("Missing Data, check if you have\n - a flatfile\n - a intern file table\n - export file from plentymarkets\n - a sheet with the stock numbers!\n")
 
... ... def main():
53 57 print("\nOpen your amazon storage report and save it as an csv.\n") print("\nOpen your amazon storage report and save it as an csv.\n")
54 58 stocklist = askopenfilename() stocklist = askopenfilename()
55 59 print("spreadsheet csv containing the current stock : ", stocklist) print("spreadsheet csv containing the current stock : ", stocklist)
60
61 # stockUpload(sheet, export, stocklist)
56 62
57 stockUpload(sheet, export, stocklist)
58 # try:
63 print("\nCreate a upload file for the SKU and Parent_SKU\nto connect existing items from amazon to plentyMarkets.\n")
59 64
65 amazon_sku_upload(sheet, export)
60 66 # In case of new attributes uncomment and watch attribute_upload.py first # In case of new attributes uncomment and watch attribute_upload.py first
61 67 # try: # try:
62 # attributeUpload(sheet)
68 # attributeUpload(sheet)
63 69 # except: # except:
64 #print("Attribute Upload failed!")
70 #print("Attribute Upload failed!")
65 71
66 72
67 73 if __name__ == '__main__': if __name__ == '__main__':
68 74 main() main()
69
70
Hints:
Before first commit, do not forget to setup your git environment:
git config --global user.name "your_name_here"
git config --global user.email "your@email_here"

Clone this repository using HTTP(S):
git clone https://rocketgit.com/user/initBasti/Amazon2PlentySync

Clone this repository using ssh (do not forget to upload a key first):
git clone ssh://rocketgit@ssh.rocketgit.com/user/initBasti/Amazon2PlentySync

Clone this repository using git:
git clone git://git.rocketgit.com/user/initBasti/Amazon2PlentySync

You are allowed to anonymously push to this repository.
This means that your pushed commits will automatically be transformed into a merge request:
... clone the repository ...
... make some changes and some commits ...
git push origin main