Цитата:
|
xcube,
диалог в стиле: испорченный телефон. |
рони,
const data = []; const datas = []; iimPlayCode('WAIT SECONDS=1'); iimPlayCode('SET !TIMEOUT 10\nTAG POS=1 TYPE=LABEL FORM=ACTION:?act=vendors ATTR=TXT:Продажа'); iimPlayCode('SET !TIMEOUT 10\nTAG POS=1 TYPE=BUTTON FORM=ACTION:?act=vendors ATTR=TXT:выбрать'); iimPlayCode('WAIT SECONDS=1'); var buy = window.document.querySelectorAll(".table-sell td[data-label='Вещь']"); //var linkList = window.document.querySelectorAll(".table-sell td[class='price']"); for (var i = 0; i < buy.length; i++) { var cName = buy[i].innerHTML.replace(/\s+/g, ''); var cPrice = buy[i].closest('tr').querySelector(".price").innerHTML.r eplace(/\s+/g, ''); var obj = { name: cName, price: cPrice } data.push(obj); } window.console.log(data); iimPlayCode('WAIT SECONDS=1'); iimPlayCode('SET !TIMEOUT 10\nTAG POS=1 TYPE=LABEL FORM=ACTION:?act=vendors ATTR=TXT:Покупка'); iimPlayCode('SET !TIMEOUT 10\nTAG POS=1 TYPE=BUTTON FORM=ACTION:?act=vendors ATTR=TXT:выбрать'); iimPlayCode('WAIT SECONDS=1'); var sell = window.document.querySelectorAll(".table-sell td[data-label='Вещь']"); for (var i = 0; i < sell.length; i++) { var cName = sell[i].innerHTML.replace(/\s+/g, ''); var cPrice = sell[i].closest('tr').querySelector(".price").innerHTML.r eplace(/\s+/g, ''); var obj2 = { name: cName, price: cPrice } datas.push(obj2); } window.console.log(data); window.console.log(datas); const dataz = Array.from(data, (v, i) => ({...v, ...datas[i]})); window.console.log(dataz) В целом - моя идея - найти все продажи (массив data), найти все покупки (массив datas), сравнить цены и если покупают дороже цены продажи - оповещать меня. |
xcube,
ок нет у вас price2 -- тогда что хотите получить в dataz ? |
рони,
for (var i = 0; i < sell.length; i++) { var cName2 = sell[i].innerHTML.replace(/\s+/g, ''); var cPrice2 = sell[i].closest('tr').querySelector(".price").innerHTML.r eplace(/\s+/g, ''); var obj2 = { name: cName2, price: cPrice2 } datas.push(obj2); } Так поровней? Хотя не работает( Получается у меня сейчас: data = [{cName, cPrice}]... datas = [{cName2, cPrice2}]... |
xcube,
var obj2 = { name: cName2, price2 сюда двойку: cPrice а не тут } var obj2 = { name: cName2, price2: cPrice2 } |
Цитата:
const datas = [{name : 1, price : 100} , {name : 2, price : 45}], datab = [{name : 1, price : 5} , {name : 2, price : 33}], dataz = Array.from(datas, (v, i) => (v.price -= datab[i].price, v)); console.log(dataz)в price будет разница цен. |
рони,
Работает! Но коряво. Суть в том, что cName и cName2 в 99% случаев располагаются в разных ячейках массива. Вообще таблица продаж состоит из 500+ объектов, а таблица покупок из 40+ Получается нужно cName сравнить с cName2, если сходство, то добавлять к объекту2 + cPrice, что бы получилось: {имя, цена покупки, цена продажи} в одном объекте и ячейке ? Как это можно реализовать? Пожалуйста :help: |
xcube,
const datas = [{name : 1, price : 100} , {name : 2, price : 45}, {name : 3, price : 400}], datab = [{name : 1, price : 5} , {name : 2, price : 33}], dataz = datab.map((v,i) => { const {name} = v , ob = datas.find(({name : k}) => k == name); if (ob) v.цена = ob.price; return v }) console.log(dataz) |
рони,
Оо супер! Тесты то, что надо! Но, когда запускаю со своим - виснет imacros с браузером Это из-за 500 объектов в массиве? или старой версии лисы и imacros может быть? |
Часовой пояс GMT +3, время: 10:26. |