Запятую в нули.

Поддержка
  • Здравствуйте, не могу решить, казалось бы простую задачу, есть переменная в ней будут лежать цифры, которые всегда разные, но в них присутствует запятая, всегда по разному, вторая после цифры или третья или запятых совсем нет, короче пример: 1,2 , 12,3 123,4 или 123 нужно убрать запятые и добавить нули, должно получится: 1200, 12300, 123400 или 123000, т. е умноженные на 1000 и помещенные тоже в переменные, мне нужно брать цифры строго в зависимости от положения запятой, т. е if 1,2- взять 1200, if 12,3- взять 12300 итд. Подскажите пожалуйста решение, желательно на кубиках, мозг горит уже весь!

  • @cryotag said in Запятую в нули.:

    Здравствуйте, не могу решить, казалось бы простую задачу, есть переменная в ней будут лежать цифры, которые всегда разные, но в них присутствует запятая, всегда по разному, вторая после цифры или третья или запятых совсем нет, короче пример: 1,2 , 12,3 123,4 или 123 нужно убрать запятые и добавить нули, должно получится: 1200, 12300, 123400 или 123000, т. е умноженные на 1000 и помещенные тоже в переменные, мне нужно брать цифры строго в зависимости от положения запятой, т. е if 1,2- взять 1200, if 12,3- взять 12300 итд. Подскажите пожалуйста решение, желательно на кубиках, мозг горит уже весь!

    Запятая в числе может быть только одна?

    1,2 == 1200
    

    или несколько?

    1,900,8 == 1900800
    
  • @Fox только одна.

  • @cryotag said in Запятую в нули.:

    @Fox только одна.

    Переведите строку в число

    b0ac98e8-f666-4ce1-ae49-725de38e7cf3-изображение.png

    и умножте полученное число на 1000

    5cc9cc5c-f6bf-4db0-9c7b-56d44f1e73fd-изображение.png

  • @Fox Хорошо, это понятно, но, как я писал ,самое главное, это выбор чисел с нулями строго в в соответствии от запятых, взять из переменной 1200, если была запятая, после первой цифры, взять 12300, если запятая была после второй цифры, т.е алгоритм такой взять в переменную число с запятой ,посмотреть на каком месте запятая,положить вдругую переменную число с нулями, в зависимости от положения запятой в первой переменной, визуально так: if 1,2 - 1200, if 12,3 -12300 ,if 123- 123000, нужен именно перебор этих комбинаций и выбор одного единственного числа с нулями на конце, строго в соответствии от положения запятой.

  • @cryotag said in Запятую в нули.:

    @Fox Хорошо, это понятно, но, как я писал ,самое главное, это выбор чисел с нулями строго в в соответствии от запятых, взять из переменной 1200, если была запятая, после первой цифры, взять 12300, если запятая была после второй цифры, т.е алгоритм такой взять в переменную число с запятой ,посмотреть на каком месте запятая,положить вдругую переменную число с нулями, в зависимости от положения запятой в первой переменной, визуально так: if 1,2 - 1200, if 12,3 -12300 ,if 123- 123000, нужен именно перебор этих комбинаций и выбор одного единственного числа с нулями на конце, строго в соответствии от положения запятой.

    Чегось? Три раза перечитал и всё равно не понял. Приведите список примеров входящих данных и результата, который вы хотите достичь

  • @Fox Попрубуем ещё:
    IF [SAVE_TEXT]==(цифра запятая цифра) ,то * 1000 и положить в переменную [1]
    ELSE
    IF [SAVE_TEXT]==(цифра цифра запятая цифра) ,то * 1000 и положить в переменную [2]
    ELSE
    IF [SAVE_TEXT]==(цифра цифра цифра) ,то * 1000 и положить в переменную [3]

  • @cryotag сделайте условие. Если полученное число меньше 10 000, то положить в переменую 1, если больше 10 000 и меньше 100 000, то переменная 2, если больше 100 000, то переменная 3
    Снимок.jpg

  • @Gryner цифры с запятыми всегда разные, запятые только на первом и втором месте после цифры

  • @cryotag said in Запятую в нули.:

    @Fox Попрубуем ещё:
    IF [SAVE_TEXT]==(цифра запятая цифра) ,то * 1000 и положить в переменную [1]
    ELSE
    IF [SAVE_TEXT]==(цифра цифра запятая цифра) ,то * 1000 и положить в переменную [2]
    ELSE
    IF [SAVE_TEXT]==(цифра цифра цифра) ,то * 1000 и положить в переменную [3]

    Я попросил вас привести примеры настоящих данных, но то, что вы описали, можно решить с помощью регулярок

    IF [SAVE_TEXT]==(\d,\d) ,то * 1000 и положить в переменную [1]
    ELSE
    IF [SAVE_TEXT]==(\d\d,\d) ,то * 1000 и положить в переменную [2]
    ELSE
    IF [SAVE_TEXT]==(\d\d\d) ,то * 1000 и положить в переменную [3]
    
  • @Fox Да именно так, приду домой проверю,спасибо за терпение и понимание

  • @cryotag,в BAS можно выполнять код в отдельном кубике.

    // Этот код может не работать корректно, если в числе будет более одной запятой или если число будет слишком большим.
    
    
    /**
     * Функция processNumber принимает строку, содержащую число с запятой и возвращает число, умноженное на 1000 и без запятой.
     * @param {string} numberString - Строка с числом.
     * @returns {number} - Число, умноженное на 1000 и без запятой.
     */
    function processNumber(numberString) {
      // Если в числе есть запятая, значит нужно добавить недостающие нули и удалить запятую.
      if (numberString.includes(',')) {
        // Определяем индекс запятой в строке.
        const commaIndex = numberString.indexOf(',');
        // Если запятая находится на втором месте, то нужно добавить 0 перед числом.
        if (commaIndex === 1) {
          numberString = '0' + numberString;
        }
        // Определяем количество знаков после запятой.
        const decimalPlaces = numberString.length - commaIndex - 1;
        // Вычисляем, сколько нулей нужно добавить в конец числа.
        const zerosToAdd = 3 - decimalPlaces;
        // Добавляем недостающие нули в конец числа.
        for (let i = 0; i < zerosToAdd; i++) {
          numberString += '0';
        }
        // Удаляем запятую из числа.
        numberString = numberString.replace(',', '');
        // Умножаем число на 1000 и возвращаем результат.
        const number = parseInt(numberString) * 1000;
        return number;
      } else {
        // Если запятой в числе нет, то нужно добавить три нуля в конец числа и вернуть результат.
        const number = parseInt(numberString + '000');
        return number;
      }
    }
    
  • @sergerdn said in Запятую в нули.:

    @cryotag,в BAS можно выполнять код в отдельном кубике.

    // Этот код может не работать корректно, если в числе будет более одной запятой или если число будет слишком большим.
    
    
    /**
     * Функция processNumber принимает строку, содержащую число с запятой и возвращает число, умноженное на 1000 и без запятой.
     * @param {string} numberString - Строка с числом.
     * @returns {number} - Число, умноженное на 1000 и без запятой.
     */
    function processNumber(numberString) {
      // Если в числе есть запятая, значит нужно добавить недостающие нули и удалить запятую.
      if (numberString.includes(',')) {
        // Определяем индекс запятой в строке.
        const commaIndex = numberString.indexOf(',');
        // Если запятая находится на втором месте, то нужно добавить 0 перед числом.
        if (commaIndex === 1) {
          numberString = '0' + numberString;
        }
        // Определяем количество знаков после запятой.
        const decimalPlaces = numberString.length - commaIndex - 1;
        // Вычисляем, сколько нулей нужно добавить в конец числа.
        const zerosToAdd = 3 - decimalPlaces;
        // Добавляем недостающие нули в конец числа.
        for (let i = 0; i < zerosToAdd; i++) {
          numberString += '0';
        }
        // Удаляем запятую из числа.
        numberString = numberString.replace(',', '');
        // Умножаем число на 1000 и возвращаем результат.
        const number = parseInt(numberString) * 1000;
        return number;
      } else {
        // Если запятой в числе нет, то нужно добавить три нуля в конец числа и вернуть результат.
        const number = parseInt(numberString + '000');
        return number;
      }
    }
    

    А вы проверяли его работу?

  • @Fox said in Запятую в нули.:

    @sergerdn said in Запятую в нули.:

    @cryotag,в BAS можно выполнять код в отдельном кубике.

    // Этот код может не работать корректно, если в числе будет более одной запятой или если число будет слишком большим.
    
    
    /**
     * Функция processNumber принимает строку, содержащую число с запятой и возвращает число, умноженное на 1000 и без запятой.
     * @param {string} numberString - Строка с числом.
     * @returns {number} - Число, умноженное на 1000 и без запятой.
     */
    function processNumber(numberString) {
      // Если в числе есть запятая, значит нужно добавить недостающие нули и удалить запятую.
      if (numberString.includes(',')) {
        // Определяем индекс запятой в строке.
        const commaIndex = numberString.indexOf(',');
        // Если запятая находится на втором месте, то нужно добавить 0 перед числом.
        if (commaIndex === 1) {
          numberString = '0' + numberString;
        }
        // Определяем количество знаков после запятой.
        const decimalPlaces = numberString.length - commaIndex - 1;
        // Вычисляем, сколько нулей нужно добавить в конец числа.
        const zerosToAdd = 3 - decimalPlaces;
        // Добавляем недостающие нули в конец числа.
        for (let i = 0; i < zerosToAdd; i++) {
          numberString += '0';
        }
        // Удаляем запятую из числа.
        numberString = numberString.replace(',', '');
        // Умножаем число на 1000 и возвращаем результат.
        const number = parseInt(numberString) * 1000;
        return number;
      } else {
        // Если запятой в числе нет, то нужно добавить три нуля в конец числа и вернуть результат.
        const number = parseInt(numberString + '000');
        return number;
      }
    }
    

    А вы проверяли его работу?

    Неа.

  • @sergerdn said in Запятую в нули.:

    А вы проверяли его работу?

    Неа.

    Проверьте, возможно вас удивит результат

  • @Fox IF [SAVE_TEXT]==(\d,\d) как в кубике действий написать? ошибку выдает. Заранее спвсибо за ответ.

  • @cryotag said in Запятую в нули.:

    @Fox IF [SAVE_TEXT]==(\d,\d) как в кубике действий написать? ошибку выдает. Заранее спвсибо за ответ.

    Это регулярное выражение, используйте его в действии "Подходит ли строка под регулярное выражение"

  • @Fox said in Запятую в нули.:

    @sergerdn said in Запятую в нули.:

    А вы проверяли его работу?

    Неа.

    Проверьте, возможно вас удивит результат

    Я обычно пишу скелет для функционала, потому пишу тест на функционал, а потом уже сам функционал.

    Если топикастер дал бы примеры с пограничными вариантами, я бы набросал тест, а потом бы уже функцию и не допустил бы таких ошибок. Все делать самому - я поленился, набросал код не сильно вникая задачу.

  • 0 Votes
    1 Posts
    345 Views
  • 0 Votes
    15 Posts
    1513 Views
  • 0 Votes
    10 Posts
    1319 Views
  • 0 Votes
    6 Posts
    2006 Views
  • 0 Votes
    5 Posts
    1360 Views