Здравствуйте
поставил ксеон новый процессор вместо ай 5
8 потоков стало вроде бы
все стало шустрее но памяти 16 гб стало не хватать
расширил до 32
по скрипту из режима записи в режим запуска поменял с помощью другого спеца порядок функций
раньше в онстартапликейшен загружал куки и файл
теперь онстартапликейшен убрал и все что в ней было объявлено закинул в начало мейна
все стало пахать
но странно ведь утверждалось что те элементы которые не будут меняться лучше как раз в онстарталикейшен можно загружать и не париться
был однопоток но все равно глючило почему то в режиме запуска
убрал в мейн из онстарьапликейшен все запуск в однопотоке норм трудится
правда была еще проблема что ставил повторять скрипт
а он через 3-4 повторения заканчивался пришлось бегать ставить метки
в общем с басом основная проблема это обучение и примеры собранные и централизованно с грамотным содержанием оформлены
интерфейс тоже звиздец какой то
я долго не мог понять где пункт выпадающего контекстного меню на элементе а оказалось в итоге что контекстное меню надо было проматывать еще дальше вниз колесиком мыши чтобы там из 15 опций низ показался
звиздец же
но в целом хоть и безплатно но хочется обучения и красивости и доубства оформления
копии бас тоже сейчас запускаются пока 3 штуки норм пашут именно паралелльно:)независимо друг от друга
кстати если кому интересно была проблема с установкой 4 планов по 8 гигабайт на материнскую плату b85+ и не шло никак
2 норм а две другие не хотели мириться
решилось через очень долгое и случайное мозговое штурмирование методом тыка
надо было в биосе включить и отключить слоты памяти ибо даже после обнуления биоса путем вытаскивания батарейки где то информация закрепилась и слоты глючили
но после отключения включения все 4 слота стали пахать и память у меня теперь 32 гигабайта:) а я уж смирился с 16
так что есть польза от совместного решени язадач и резонанса
аурауспешайкая
Как скопировать большой файл из txt в xls, xlsx , через бас?
-
Есть много файлов в формате txt, в каждом от 200 до 3000+ строк(количество строк всегда разное), и около 50 "столбцов"(количество столбцов всегда постоянно), в строках есть знаки табуляции. Задача копировать из текстового файла в новый файл в формате таблицы.
Знаю, есть решение на форуме, для записи по одной ячейке циклом. Но мне этот вариант не подходит. Так каждый раз приходиться дописывать xlsx и пересохранять, после каждой ячейки или максимум строки целиком. А это в некоторых случаях 3000+ раз и таких файлов надо обрабатывать сотни в день, с учётом того, что необходимо ставить паузы в хотя бы в пару секунд каждый раз для корректного сохранения - это нереально, не говоря уже о дикой нагрузке на жд. Проблема в том, что я не знаю как сформировать код таким образом, чтобы сохранение происходило один раз, при этом записав все данные, с разным каждый раз количеством строк. Как можно решить данную задачу? -
@Vennix Вам надо хоть немного знать js и использовать модуль для node js, например этот https://github.com/dtjohnson/xlsx-populate
Там есть примеры кода, вот например сразу запишет все данные в таблицу, начиная с А1
workbook.sheet(0).cell("A1").value([ [1, 2, 3], [4, 5, 6], [7, 8, 9] ]); -
-
@UserTrue Извиняюсь за наглость, но я похоже вообще не понял о чем речь, можете простой пример бас показать? На входе txt файл, в несколько строк, значения в строках разделены знаком табуляции. Все данные с файла записываются равномерно в xls, начиная с определенной ячейки, например A10
-
@Vennix
В архиве пример
excel.zip[[TEXT]] - это путь к файлу с текстом
[[TEMPLATE]] - путь к шаблону'use string' const XlsxPopulate = require('xlsx-populate'); const fs = require('fs'); const path = require('path'); const file = fs.readFileSync([[TEXT]], 'utf8') .split(/\r?\n/) .map(el=> el.split(/\t/)) await XlsxPopulate.fromFileAsync([[TEMPLATE]]) .then(workbook => { // Modify the workbook. workbook.sheet(0).cell("A1").value(file); // Write to file. let writePath = path.parse([[TEMPLATE]]); writePath.name = path.parse([[TEXT]]).name writePath.base = ''; writePath = path.format(writePath); return workbook.toFileAsync(writePath); });