Цитата:
|
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, время: 08:22. |