Xlfn concat что это
The site is about Microsoft Excel.
What’s The Story?
What Is XLFN?
xlfn is a prefix added to functions that don’t exist in the version of Excel that you are using.
You have Excel 2013 and your friend has a newer version of Excel (Office 365 or Excel 2016). He uses a cool new function and sends the file to you. As you have Excel 2013 this cool new function doesn’t yet exist and you see xlfn in front of the function.
Recent XLFN Example
Last year I discovered David Hager’s Excel blog. He shares a lot of neat ideas. I recently saw this post: Conditional Format Rows in List 1 that are Not in List 2
When I opened the file I noticed that the solution wasn’t working for me. I went back to David’s post and looked at this pic:
I noticed that David used the CONCAT function. This must be a new Excel 2016 (or Office365?) function! There are a bunch of really interesting new functions but I’m still using Excel 2013.
What Does Microsoft Recommend?
OK. So, Is There A Workaround?
Although not as easy as David’s solution we can still produce the same end result.
Here are the steps to my workaround solution:
Excel 2013 Workaround Solution
Here is David’s Excel file that includes my workaround solution for those that don’t have Excel 2016.
Learn From Excel MVP David Hager
You can find David at https://dhexcel1.wordpress.com/ and https://twitter.com/dhExcel
About Me
My name is Kevin Lehrbass. I live in Markham, Ontario, Canada. I’ve been studying, supporting, building, troubleshooting, teaching and dreaming in Excel since 2001. I’m a Data Analyst.
There are so many amazing things that you can do with Excel.
Away from Excel I enjoy learning Spanish, playing Chess, hanging out with Cali and Fenton and reading Excel books 🙂
ABOUT THE AUTHOR
Kevin Lehrbass
How about Microsoft make the stand alone version of Office 2016 match the Office 365 version of Excel!
This can also happen when you have teammates working in a different language Excel than you. the xlfn, acts just like a flag that your local Excel creates to indicate that it tried looking for that formula but didn’t find it.
I don’t really know who on Ms decided that formulas in Excel should be translated and not ported between languages when you open the workbook, most surely in an effort to increase end-user retention of the formulae.
BITRSHIFT is another function from older versions of excel. It’s available in LibreOffice Calc.
Edit: should be “missing from older versions”
Huh you can also just use replace _xlfn.CONCAT to CONCATENATE
Leave a Reply Cancel reply
Sometimes I write a practical ‘how to’ post and other times I explore a crazy idea and build something unique. I love working with data in Microsoft Excel!
Как сцепить ячейки в Excel при помощи различных функций и операторов
В этом руководстве вы узнаете о различных способах соединения текстовых строк, ячеек, диапазонов, столбцов и строк в Excel с использованием функции СЦЕПИТЬ, СЦЕП, ОБЪЕДИНИТЬ и оператора «&».
В этом руководстве мы собираемся изучить различные методы «склеивания» данных, чтобы вы смогли выбрать наиболее подходящий для себя.
Что значит и как «сцепить» в Excel?
По сути, существует два способа объединения данных в таблицах:
Когда вы объединяете ячейки, вы «физически» объединяете две или более клеточки в одну. В результате у вас есть одно большое поле, которое отображается в нескольких строчках и / или столбиках на вашем рабочем листе.
Команда СЦЕПИТЬ предназначена для объединения различных фрагментов текста или объединения данных из нескольких ячеек в одну.
Синтаксис её выглядит следующим образом:
Замечание. В Excel 2016, 2019, Excel Online и Excel Mobile СЦЕПИТЬ заменяется функцией СЦЕП (CONCAT в английской версии), которая имеет точно такой же синтаксис. Хотя функция СЦЕПИТЬ сохраняется для обратной совместимости, рекомендуется использовать вместо нее СЦЕП, поскольку Microsoft не дает никаких обещаний, что старая функция будет доступна в будущих версиях программы.
Как сцепить несколько ячеек.
Простейшее выражение для конкатенации содержимого A1 и B1 выглядит следующим образом:
Обратите внимание, что они будут соединены друг с другом без разделителя, как в строке 3 на рисунке ниже. Думаю, такой вариант нас не устроит.
Чтобы разделить их пробелом, введите “ “ во втором аргументе, как в строке 4.
Чтобы разделить объединенные значения с другими разделителями, такими как запятая, пробел или косая черта, смотрите здесь.
Объединение текстовой строки и ссылки.
Нет необходимости ограничиваться только объединением значений ячеек. Вы также можете добавить к ним какой-либо текст, чтобы сделать результат более значимым и понятным. Например:
Приведенный выше пример информирует пользователя о завершении определенного задания. Обратите внимание, что мы добавляем пробел перед словом «выполнено», чтобы отделить соединенные текстовые элементы.
Естественно, вы можете добавить текст в начале или в середине формулы СЦЕПИТЬ:
Между объединенными элементами добавляется пробел (» «), поэтому результат отображается как «задание 2», а не «задание2».
Объединение текстовой строки и вычисляемой формулы
Чтобы сделать результат, возвращаемый каким-то расчётом, более понятным для ваших пользователей, вы можете связать его с текстовым пояснением. Оно объяснит, как следует оценивать получившееся.
Например, вы можете использовать следующую формулу для возврата текущей даты:
Чтобы вычисления с этой функцией всегда давали правильные результаты, запомните следующие простые правила:
Оператор «&» для объединения текста
Этот метод очень удобен во многих случаях, потому что ввод знака амперсанда (&) гораздо быстрее, чем ввод целого выражения 🙂
Подобно функции СЦЕПИТЬ, вы можете использовать «&» для объединения различных текстовых строк, значений ячеек и результатов, возвращаемых другими вычислениями.
Чтобы увидеть оператор конкатенации в действии, давайте перепишем примеры, уже рассмотренные выше:
Слить вместе A1 и B1:
Соедините A1 и B1 через пробел:
Соединить A1, B1 и текст:
Собрать воедино текст и результат вычисления текущей даты:
Как показано на скриншоте ниже, функция СЦЕПИТЬ и оператор «&» возвращают идентичные результаты:
Оператор «&» против функции СЦЕПИТЬ
Многие пользователи задаются вопросом, какой же более эффективный способ объединения строк – использовать СЦЕПИТЬ или оператор «&».
Кроме этого, нет никакой разницы между этими двумя методами конкатенации, и нет никакой разницы в скорости работы между СЦЕПИТЬ и «&».
А поскольку число 255 действительно большое, и в реальных задачах кому-то вряд ли когда-нибудь понадобится объединить столько элементов, разница сводится к удобству и простоте использования. Некоторым пользователям формулы легче читать, я лично предпочитаю использовать метод «&». Так что, просто придерживайтесь метода конкатенации, который вам удобнее.
Объединить с пробелом, запятой и другими символами
В ваших рабочих листах часто может потребоваться собрать воедино элементы таким образом, чтобы они содержали запятые, пробелы, различные знаки пунктуации или другие символы, такие как дефис или косая черта.
Для этого просто включите нужный символ в формулу объединения. Не забудьте заключить этот символ в кавычки, как показано в следующих примерах.
Так можно сцепить с пробелом:
Объединение через запятую:
Соединяем с дефисом:
На рисунке показано, как могут выглядеть результаты:
Объединение текста с переносами строк.
Чаще всего вы бы разделяли соединенные текстовые элементы знаками препинания и пробелами, как показано в предыдущем примере. Однако в некоторых случаях может потребоваться разделить их с помощью переноса строки или возврата каретки. Типичным примером является объединение почтовых адресов из информации в отдельных столбцах.
Проблема заключается в том, что вы не можете просто ввести разрыв строки, как обычный символ, и поэтому необходима специальная функция CHAR для предоставления соответствующего кода ASCII в формулу конкатенации:
В этом примере у нас есть части адреса в столбцах от A до F, и мы соединяем их в столбце G с помощью оператора конкатенации «&». Объединенные элементы разделяются запятой («,»), пробелом (» «) и переводом строки СИМВОЛ(10):
Таким же образом вы можете разделить связанные части и другими символами, такими как:
Хотя проще включить печатные символы в формулу конкатенации, просто набрав их в двойных кавычках, как мы это делали в предыдущем примере.
В любом случае, все четыре из приведенных ниже выражений дают одинаковые результаты:
=СЦЕПИТЬ(A1; СИМВОЛ(47); B1)
Как объединить столбцы
Чтобы собрать воедино два или более столбца, вы просто вводите обычную формулу объединения в первой клетке, а затем копируете ее в другие, перетаскивая маркер заполнения (маленький квадрат, который появляется в нижнем правом углу выделенной клетки).
Например, чтобы интегрировать два столбца (столбцы A и B), разделяя их содержимое пробелом, введите следующую формулу в C2, а затем скопируйте ее ниже. При перетаскивании маркера заливки для копирования указатель мыши изменится на крест, как показано на снимке экрана ниже:
Обратите внимание, что программа сама определяет, как далеко копировать после двойного щелчка дескриптор заливки, основываясь на ячейках, указанных вами в качестве аргументов. Если в вашей таблице окажутся пустые места, скажем, A6 и B6 в этом примере были пустыми, будет предложено скопировать только до строки 5. В этом случае вам потребуется вручную перетащить маркер заполнения ещё дальше, чтобы объединить все столбцы ниже.
Как объединить диапазон.
Объединение значений из нескольких ячеек может потребовать некоторых усилий, поскольку функция СЦЕПИТЬ в Excel не воспринимает массивы и требует использования одной ссылки в каждом аргументе.
Чтобы интегрировать несколько ячеек, скажем, от А1 до А4, вам понадобится что-то подобное:
При присоединении к довольно небольшому диапазону нет ничего сложного, чтобы ввести все ссылки в строке формул. Но было бы весьма утомительно добавлять большой диапазон, указывая каждую ссылку вручную. Ниже вы найдете 3 метода быстрой конкатенации.
Метод 1. Используем клавишу CTRL.
Чтобы быстро выбрать несколько ячеек, вы можете нажать клавишу CTRL и затем щелкнуть по каждой из тех, которые вы хотите использовать в качестве аргумента функции. Вот подробные шаги:
Замечание. При использовании этого метода вы должны нажать на каждую отдельную ячейку. Выбор диапазона с помощью мыши добавит в формулу массив, который функция СЦЕПИТЬ не понимает.
Способ 2. Используйте ТРАНСП
Когда вам нужно консолидировать огромный диапазон, состоящий из десятков или сотен ячеек, предыдущий метод недостаточно удобен и быстр. Ведь он требует нажатия на каждую из них.
В этом случае лучше использовать функцию ТРАНСП (TRANSPOSE в английской версии) для возврата массива, а затем заменить его ссылками одним махом.
Замечание. Какой бы метод вы ни использовали, объединенное значение в С1 является текстом (обратите внимание на выравнивание по левому краю), даже если каждое из исходных значений является числом. Это связано с тем, что СЦЕПИТЬ всегда возвращает текстовую фразу независимо от типа данных источника.
Объединение чисел и дат в различных форматах
Когда вы объединяете какие-то слова с числом или датой, вы можете форматировать результат по-разному в зависимости от набора данных. Чтобы сделать это, вставьте функцию ТЕКСТ в свою формулу.
ТЕКСТ(значение; формат) имеет два аргумента:
Ниже приведены еще несколько примеров, объединяющих текст, дату и число:
Используем новые функции СЦЕП и ОБЪЕДИНИТЬ.
Долгое время СЦЕПИТЬ была первой функцией, о которой мы думали, когда нам нужно было соединить текст в Excel. Но несколько новых игроков недавно вошли в игру. Я говорю о ОБЪЕДИНИТЬ (или TEXTJOIN) и СЦЕП ( или CONCAT), разработанных, чтобы помочь вам интегрировать несколько значений. Используйте эти простые функции всякий раз, когда вам нужно сложить вместе части имен, адресов или фраз, соединить цифры и слова. В настоящее время они доступны в Excel 2016, Excel Online и Mobile, Excel для планшетов и телефонов Android.
Вот как она выглядит:
ОБЪЕДИНИТЬ(разделитель, игнорировать_пустые, ТЕКСТ1, [ТЕКСТ2],…)
Он имеет 3 обязательных и 1 необязательный аргументы:
Для текстовых элементов может быть не более 252 аргументов. Если результат превышает предел 32767 символов, она возвращает ошибку #ЗНАЧ!.
Представленный как часть обновления в феврале 2016 года, СЦЕП заменяет функцию СЦЕПИТЬ в Excel. Работает почти так же, но существенное отличие состоит в том, что теперь можно работать с диапазонами данных, а не перечислять каждую позицию по очереди. Согласитесь, это здорово упрощает работу.
Кроме того, СЦЕП является стандартной функцией, используемой в Google Sheets.
СЦЕПИТЬ продолжает поддерживаться для обеспечения совместимости с предыдущими версиями Excel.
Выглядит это следующим образом:
Есть только два аргумента, один из которых является необязательным:
Для текстовых данных может быть не более 253 аргументов.
Ранее, если вам нужно было объединить текст из нескольких ячеек, необходимо было указать каждую из них по отдельности. С новыми функциями ОБЪЕДИНИТЬ и СЦЕП вы можете просто ссылаться на диапазон и комбинировать текстовые фразы из диапазонов с разделителем или без него.
Скажем, вы хотите сгруппировать вместе части телефонных номеров. Применяя СЦЕПИТЬ, вам нужно будет вводить адреса один за другим, как в этом примере.
В этом случае СЦЕП выглядит гораздо компактнее. Все, что вам нужно сделать, это просто выбрать диапазон для объединения.
В то же время, СЦЕП и СЦЕПИТЬ выглядят одинаково, когда вам нужно соединить части текста в одну фразу с помощью разделителей.
Как легко увидеть, они не обрабатывают пустые ячейки, что приводит к появлению лишних пробелов (например, в G3 и G8).
Поэтому функции ОБЪЕДИНИТЬ суждено стать действительно популярным выбором для пользователей, работающих с большими объемами текстовых данных.
Вы просто указываете разделитель (если нужно), выбираете «игнорировать пустые» и определяете диапазон. Это гораздо более разумное и быстрое решение.
Если у вас есть Excel 2016, изучите применение ОБЪЕДИНИТЬ и СЦЕП, чтобы увидеть, насколько они полезны, и попрощайтесь с традиционными способами при объединении.
Xlfn concat что это
Функция СЦЕПИТЬ в Excel
Microsoft Excel Функция CONCAT объединяет тексты из нескольких столбцов, строк или диапазонов вместе.
Синтаксис
аргументы
Текст 1 (Обязательно): текстовый элемент, который нужно объединить.
Текст 2 (Необязательно): дополнительный текстовый элемент, который нужно присоединить.
Текстовые аргументы могут быть:
Возвращаемое значение
Вернуть строковое или текстовое значение без разделителя.
Функция Примечание
1. Эту функцию CONCAT можно применить к Office 2019 и Office 365 (убедитесь, что у вас установлена последняя версия Office) в Windows или Mac.
2. Если вы используете Office 2016 или более ранние версии, используйте функцию СЦЕПИТЬ.
3. Вы можете комбинировать до 255 текстовых аргументов одновременно.
Примеры
В этом разделе приведены примеры функции CONCAT, чтобы показать вам, как ее использовать в Excel.
Пример 1: объединить тексты из нескольких ячеек в одну
Как показано на скриншоте ниже, как объединить тексты в разных столбцах B, C, D и E вместе и поместить результат в столбец F? Пожалуйста, сделайте следующее, чтобы это сделать.
1. Выберите пустую ячейку (говорит F3) для вывода объединенного текста, скопируйте в нее формулу ниже и нажмите Enter ключ. Затем перетащите маркер заполнения вниз, чтобы получить все результаты. Смотрите скриншот:
=CONCAT(B3:E3)
Пример 2: объединить тексты из нескольких ячеек в одну с определенным разделителем
Предположим, что есть два столбца, содержащие отдельно имя и фамилию, и вы хотите объединить имя и фамилию в одну ячейку с разделителем пробелом, попробуйте следующий метод.
1. Выберите пустую ячейку, скопируйте в нее приведенную ниже формулу и нажмите клавишу Enter. Затем перетащите маркер заполнения вниз, чтобы получить все результаты.
=CONCAT(B3,» «,C3)
Заметки:
1. B3 содержит первое имя, а C3 содержит второе имя.
2. «» означает, что вы объедините имя и фамилию с пробелом. Если вы хотите комбинировать с запятой, замените пробел запятой, например «,» или другим разделителем, который вам нужен.
3. Если вы хотите, чтобы все тексты были прописными или строчными после присоединения, примените формулу ниже.
=UPPER(CONCAT(B3,» «,C3))
=LOWER(CONCAT(B3,» «,C3))
3. Вы можете включить другое текстовое значение в функцию CONCAT напрямую, заключив текст в двойные кавычки.
=CONCAT(B3,» «,C3,»,», «Class 1»)
Другие статьи CONCATENATE:
Лучшие инструменты для работы в офисе
Working with Formulas
In general a formula in Excel can be used directly in the write_formula() method:
However, there are a few potential issues and differences that the user should be aware of. These are explained in the following sections.
Non US Excel functions and syntax
Excel stores formulas in the format of the US English version, regardless of the language or locale of the end-user’s version of Excel. Therefore all formula function names written using XlsxWriter must be in English:
Also, formulas must be written with the US style separator/range operator which is a comma (not semi-colon). Therefore a formula with multiple values should be written as follows:
If you have a non-English version of Excel you can use the following multi-lingual formula translator to help you convert the formula. It can also replace semi-colons with commas.
Formula Results
XlsxWriter doesn’t calculate the result of a formula and instead stores the value 0 as the formula result. It then sets a global flag in the XLSX file to say that all formulas and functions should be recalculated when the file is opened.
This is the method recommended in the Excel documentation and in general it works fine with spreadsheet applications. However, applications that don’t have a facility to calculate formulas will only display the 0 results. Examples of such applications are Excel Viewer, PDF Converters, and some mobile device applications.
If required, it is also possible to specify the calculated result of the formula using the optional value parameter for write_formula() :
The value parameter can be a number, a string, a bool or one of the following Excel error codes:
It is also possible to specify the calculated result of an array formula created with write_array_formula() :
However, using this parameter only writes a single value to the upper left cell in the result array. For a multi-cell array formula where the results are required, the other result values can be specified by using write_number() to write to the appropriate cell:
Dynamic Array support
Excel introduced the concept of “Dynamic Arrays” and new functions that use them in Office 365. The new functions are:
The following special case functions were also added with Dynamic Arrays:
Dynamic arrays are ranges of return values that can change in size based on the results. For example, a function such as FILTER() returns an array of values that can vary in size depending on the the filter results. This is shown in the snippet below from Example: Dynamic array formulas :
Which gives the results shown in the image below. The dynamic range here is “F2:I5” but it could be different based on the filter criteria.
It is also possible to get dynamic array behavior with older Excel functions. For example, the Excel function =LEN(A1) applies to a single cell and returns a single value but it is also possible to apply it to a range of cells and return a range of values using an array formula like <=LEN(A1:A3)>. This type of “static” array behavior is called a CSE (Ctrl+Shift+Enter) formula. With the introduction of dynamic arrays in Excel 365 you can now write this function as =LEN(A1:A3) and get a dynamic range of return values. In XlsxWriter you can use the write_array_formula() worksheet method to get a static/CSE range and write_dynamic_array_formula() to get a dynamic range. For example:
Which gives the following result:
The difference between the two types of array functions is explained in the Microsoft documentation on Dynamic array formulas vs. legacy CSE array formulas. Note the use of the word “legacy” here. This, and the documentation itself, is a clear indication of the future importance of dynamic arrays in Excel.
For a wider and more general introduction to dynamic arrays see the following: Dynamic array formulas in Excel.
The Implicit Intersection Operator, “@”, is used by Excel 365 to indicate a position in a formula that is implicitly returning a single value when a range or an array could be returned.
There is an implicit conversion here of the range of input values, “A1:A3”, to a single value “A1”. Since this was the default behavior of older versions of Excel this conversion isn’t highlighted in any way. But if you open the same file in Excel 365 it will appear as follows:
The result of the formula is the same (this is important to note) and it still operates on, and returns, a single value. However the formula now contains a “@” operator to show that it is implicitly using a single value from the given range.
Finally, if you entered this formula in Excel 365, or with write_dynamic_array_formula() in XlsxWriter, it would operate on the entire range and return an array of values:
If you are encountering the Implicit Intersection Operator “@” for the first time then it is probably from a point of view of “why is Excel/XlsxWriter putting @s in my formulas”. In practical terms if you encounter this operator, and you don’t intend it to be there, then you should probably write the formula as a CSE or dynamic array function using write_array_formula() or write_dynamic_array_formula() (see the previous section on Dynamic Array support ).
A full explanation of this operator is shown in the Microsoft documentation on the Implicit intersection operator: @.
In the section above on Dynamic Array support we saw that dynamic array formulas can return variable sized ranges of results. The Excel documentation refers to this as a “Spilled” range/array from the idea that the results spill into the required number of cells. This is explained in the Microsoft documentation on Dynamic array formulas and spilled array behavior.
Unfortunately, Excel doesn’t store the formula like this and in XlsxWriter you need to use the explicit function ANCHORARRAY() to refer to a spilled range. The example in the image above was generated using the following:
The Excel 365 LAMBDA() function
Note: at the time of writing the LAMBDA() function in Excel is only available to Excel 365 users subscribed to the Beta Channel updates.
Consider the following Excel example which converts the variable temp from Fahrenheit to Celsius:
This could be called in Excel with an argument:
Or assigned to a defined name and called as a user defined function:
This is similar to this example in Python:
The formula is written as follows:
Note, that the parameters in the LAMBDA() function must have a “_xlpm.” prefix for compatibility with how the formulas are stored in Excel. These prefixes won’t show up in the formula, as shown in the image.
The LET() function is often used in conjunction with LAMBDA() to assign names to calculation results.
Formulas added in Excel 2010 and later
When written using write_formula() these functions need to be fully qualified with a _xlfn. (or other) prefix as they are shown the list below. For example:
These functions will appear without the prefix in Excel:
Alternatively, you can enable the use_future_functions option in the Workbook() constructor, which will add the prefix as required:
If the formula already contains a _xlfn. prefix, on any function, then the formula will be ignored and won’t be expanded any further.
Enabling the use_future_functions option adds an overhead to all formula processing in XlsxWriter. If your application has a lot of formulas or is performance sensitive then it is best to use the explicit _xlfn. prefix instead.
The dynamic array functions shown in the Dynamic Array support section above are also future functions:
However, since these functions are part of a powerful new feature in Excel, and likely to be very important to end users, they are converted automatically from their shorter version to the explicit future function version by XlsxWriter, even without the use_future_function option. If you need to override the automatic conversion you can use the explicit versions with the prefixes shown above.
Using Tables in Formulas
Worksheet tables can be added with XlsxWriter using the add_table() method:
If you need to know the name of the table, for example to use it in a formula, you can get it as follows:
When used in a formula a table name such as TableX should be referred to as TableX[] (like a Python list):
Dealing with formula errors
Finally if you have completed all the previous steps and still get a #NAME? error you can examine a valid Excel file to see what the correct syntax should be. To do this you should create a valid formula in Excel and save the file. You can then examine the XML in the unzipped file.
The following shows how to do that using Linux unzip and libxml’s xmllint to format the XML for clarity: