Ошибка времени выполнения «1004» Определенная приложением или объектная ошибка. при использовании цикла for и Cells () [duplicate]

Многие объяснения уже присутствуют, чтобы объяснить, как это происходит и как это исправить, но вы также должны следовать рекомендациям, чтобы избежать NullPointerException вообще.

См. также: A хороший список лучших практик

Я бы добавил, очень важно, хорошо использовать модификатор final. Использование "окончательной" модификатор, когда это применимо в Java

Сводка:

  1. Используйте модификатор final для обеспечения хорошей инициализации.
  2. Избегайте возврата null в методы, например, при возврате пустых коллекций.
  3. Использовать аннотации @NotNull и @Nullable
  4. Быстрое завершение работы и использование утверждений, чтобы избежать распространения нулевых объектов через все приложение, когда они не должен быть пустым.
  5. Сначала используйте значения с известным объектом: if("knownObject".equals(unknownObject)
  6. Предпочитают valueOf() поверх toString ().
  7. Используйте null safe StringUtils StringUtils.isEmpty(null).

5
задан chris neilsen 14 June 2014 в 05:42
поделиться

2 ответа

Его комбинация адресации R1C1 и A1. Вам нужно выбрать один метод и использовать его для обеих частей. Обратите внимание: если вы введете =f(R[-1]C[0],Sheet1!F16) в ячейку, вы получите ошибку по той же причине.

Вы говорите, что вам нужно использовать стиль R1C1 для первого адреса, но (предполагая, что это происходит потому, t хотите абсолютный адрес), вы можете использовать .Offset вместо

ActiveCell.Value = "=f(" & ActiveCell.Offset(-1, 0).Address(False, False) _
 & ",Sheet1!" & ColumnLetter & i & ")"
9
ответ дан chris neilsen 19 August 2018 в 03:14
поделиться
  • 1
    Совершенно, именно то, что я хотел, и работает как шарм. Жаль, что вы не можете смешивать форматы ... Мне повезло, что одна из относительных переменных, которые мне нужны, просты в разработке. Спасибо за ваше время! – Derek 17 October 2011 в 10:04
  • 2
    +1 хорошо покрыто. – brettdj 18 October 2011 в 06:51

Апостроф означает Excel, что он должен интерпретировать его как текст.

Записать его в ActiveCell.Formula. Таким образом, это признается как Формула.

1
ответ дан Delcon 19 August 2018 в 03:14
поделиться
  • 1
    Это не сработает, кавычки добавляются Excel при создании формулы – JMax 17 October 2011 в 08:59
  • 2
    Я понимаю, что это не работает ... есть ли какая-нибудь работа? – Derek 17 October 2011 в 09:02
Другие вопросы по тегам:

Похожие вопросы: