Конвертация файла ДБФ со строковыми полями длиной > 254 байт в обычный ДБФ

30.09.10

Разработка - Инструментарий разработчика

В 1С 7.7 под ДБФ возможно хранение строковых реквизитов справочников и документов с длиной более 255 символов. Попробуйте открыть такой файл через, например в FoxPro и увидите кашу... Предлагаемая обработка решает только одну специфическую задачу - превращает такую таблицу в стандартный ДБФ-файл.

Файлы

ВНИМАНИЕ: Файлы из Базы знаний - это исходный код разработки. Это примеры решения задач, шаблоны, заготовки, "строительные материалы" для учетной системы. Файлы ориентированы на специалистов 1С, которые могут разобраться в коде и оптимизировать программу для запуска в базе данных. Гарантии работоспособности нет. Возврата нет. Технической поддержки нет.

Наименование Скачано Купить файл
Обработка конвертации ДБФ
.epf 10,32Kb
23 2 500 руб. Купить

Подписка PRO — скачивайте любые файлы со скидкой до 85% из Базы знаний

Оформите подписку на компанию для решения рабочих задач

Оформить подписку и скачать решение со скидкой

Вы можете заказать платную доработку или адаптацию этой разработки под вашу конфигурацию на «Бирже заказов».

  • 0% комиссии — оплата напрямую исполнителю;
  • Исполнители любого масштаба — от отдельных специалистов до команд под проект;
  • Прямой обмен контактами между заказчиком и исполнителем;
  • Безопасная сделка — при необходимости;
  • Рейтинги, кейсы и прозрачная система откликов.

В 1С 7.7 под ДБФ возможно хранение строковых реквизитов справочников и документов с длиной более 255 символов. Я понял это случайно, пытаясь выбрать данные из такой таблицы прямым запросом через VFPOLEDB. Долго не мог понять, почему вместо результата получается каша...

Предлагаемая обработка решает только одну специфическую задачу - превращает такую таблицу в стандартный ДБФ-файл. При этом длинные строковые поля делятся на несколько более коротких с длиной менее 254 байт.

Также обработка может служить примером работы с бинарными файлами из 1С8 с использованием ADODB.Stream.

Обработка под версию 8.2!!

Вступайте в нашу телеграмм-группу Инфостарт

См. также

Инструментарий разработчика Чистка данных Свертка базы Инструменты администратора БД Системный администратор Программист Руководитель проекта 1С:Предприятие 8 1С:ERP Управление предприятием 2 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х 1С:Управление нашей фирмой 3.0 Россия Платные (руб)

Инструмент представляет собой обработку для проведения свёртки или обрезки баз данных. Работает на ЛЮБЫХ конфигурациях (УТ, БП, ERP, УНФ, КА и т.д.). Поддерживаются серверные и файловые базы, управляемые и обычные формы. Может выполнять свертку одновременно в несколько потоков. А так же автоматически, без непосредственного участия пользователя. Решение в Реестре отечественного ПО

24900 руб.

20.08.2024    68611    360    164    

313

Инструментарий разработчика Роли и права Запросы СКД Программист Руководитель проекта 1С:Предприятие 8 Платные (руб)

Инструменты для разработчиков 1С 8.3: Infostart Toolkit. Автоматизация и ускорение разработки на управляемых формах. Легкость работы с 1С.

16500 руб.

02.09.2020    259056    1430    421    

1165

Пакетная печать Печатные формы Инструментарий разработчика Программист 1С:Предприятие 8 Платные (руб)

Расширение для создания и редактирования печатных форм в системе 1С:Предприятие 8.3. Благодаря конструктору можно значительно снизить затраты времени на разработку печатных форм, повысить качество и прозрачность разработки, а также навести порядок в многообразии корпоративных печатных форм. Обновление версии от 21.04.26

22570 руб.

06.10.2023    38309    107    46    

122

Инструментарий разработчика Нейросети Платные (руб)

Первые попытки разработки на 1С с использованием больших языковых моделей (LLM) могут разочаровать. LLMки сильно галлюцинируют, потому что не знают устройства конфигураций 1С, не знают нюансов синтаксиса. Но если дать им подсказки с помощью MCP, то результат получается кардинально лучше. Далее в публикации: MCP для поиска по метаданным 1С, справке синтакс-помощника и проверки синтаксиса.

15250 руб.

25.08.2025    55342    111    29    

123

Мастера заполнения Поиск данных Инструментарий разработчика Подбор и обработка объектов 1С 8.3 1С 8.5 Платные (руб)

Infostart MagicInput улучшает подбор в полях ввода 1С: ищет по любой части названия и по нескольким ключевым фрагментам, распознаёт ввод в другой раскладке и показывает иконки/статусы объектов прямо в списке. Поддерживает вставку навигационной ссылки/представления документа для автоподбора; для разработчиков доступны поиск по GUID и полному имени предопределённого. Работает в управляемых формах и подключается в большинстве конфигураций 1С 8.3/8.5.

6000 руб.

25.02.2026    3714    14    1    

16

Инструменты администратора БД Инструментарий разработчика Роли и права Программист 1С:Предприятие 8 1C:Бухгалтерия Россия Платные (руб)

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

17000 руб.

10.11.2023    25326    93    46    

102

Инструментарий разработчика Программист 1С:Предприятие 8 Платные (руб)

Инструмент для написания и отладки кода в режиме «1С:Предприятие». Представляет собой консоль кода с возможностью пошаговой отладки, просмотра значений переменных любых типов, использования процедур и функций, просмотра стека вызовов, вычисления произвольных выражений на встроенном языке в контексте точки останова, синтаксического контроля и остановки по ошибке. В консоли используется удобный редактор кода с подсветкой, контекстной подсказкой, возможностью вызова конструкторов запроса и форматной строки. 1.3.11 Доработан механизм контекстной подсказки по метаданным

9500 руб.

17.05.2024    52964    182    63    

216
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. Abadonna 3977 29.09.10 20:03 Сейчас в теме
Попробуйте открыть такой файл через объект XBase восьмерки и увидите кашу...

Попробовал.
Вот код на 7.7 для заполнения реквизита на 500 символов:
Процедура Сформировать()
Спр=СоздатьОбъект("Справочник.Тест");
Спр.НайтиПоКоду("1");
Стр="";
Для А=1 По 125 Цикл
Стр=Стр+"Test";
КонецЦикла;
Спр.Реквизит=Стр;
Спр.Записать();
КонецПроцедуры
А на картинке - результат на объекте XBase восьмерки
P.S. И листер cdbfview от Тотала - без базаров
P.P.S. Я даже догадываюсь, какие именно поля тебя смутили: которые имеют в 7.7 тип "неорганиченная длина", но это уже не строковые поля ;)
Прикрепленные файлы:
2. alex_bob 259 30.09.10 16:18 Сейчас в теме
(1) Картинками не убедил. Реквизит на 500 символов в XBase восьмерки обрезается до 244 символов. На картинке видно меньше 200. Если после этого реквизита есть еще реквизиты, то в них то каша и начинается. Попробуй сделать длину 260 символов и потом еще 10 реквизитов по 10 символов.
Про Total ничего не могу сказать...
3. Abadonna 3977 30.09.10 16:44 Сейчас в теме
(3) Тогда считай, что ниже -- фотомонтаж :D :D
Процедура КнопкаСформироватьНажатие(Кнопка)
База= Новый XBase;
База.ОткрытьФайл("c:\MiracleV8_TestBase77\SC16.DBF");
База.Первая();
Стр=База.ПолучитьЗначениеПоля("SP18");
Сообщить("Длина поля SP18= "+СтрДлина(Стр));
КонецПроцедуры

Прикрепленные файлы:
6. alex_bob 259 30.09.10 17:26 Сейчас в теме
(3),(4) Хорошо, c XBase убедил, получается я напутал. :( Остается VFPOLEDB. Фразу про XBASE из описания уберу...
Abadonna; +1 Ответить
4. Abadonna 3977 30.09.10 16:53 Сейчас в теме
На даже больше:
заполняем
Процедура Сформировать()
Спр=СоздатьОбъект("Справочник.Тест");
Спр.ВыбратьЭлементы();
Спр.НайтиПоКоду("1");
Стр="";
Для А=1 По 490 Цикл
Стр=Стр+"F";
КонецЦикла;
Стр=Стр+"А_ТутКонец";
Спр.Реквизит=Стр;
Спр.Записать();
КонецПроцедуры
А этим кодом будем смотреть
Процедура КнопкаСформироватьНажатие(Кнопка)
База= Новый XBase;
База.ОткрытьФайл("c:\MiracleV8_TestBase77\SC16.DBF");
База.Первая();
Стр=База.ПолучитьЗначениеПоля("SP18");
Сообщить("Длина поля SP18= "+СтрДлина(Стр));
Право=Прав(Стр,10);
Сообщить(Право);
КонецПроцедуры
И результат (фотомонтаж, конечно :D )
____________
Да! И dbf-ку не пожалею. Лови
Прикрепленные файлы:
SC16.DBF
5. Abadonna 3977 30.09.10 17:05 Сейчас в теме
А в следующий раз загляни в базу 7.7 и обрати внимание на такие интересные файлы, как
1SBLOB.DBF (вот они как раз для полей BLOB - реквизит неограниченной длины)
7. hogik 447 30.09.10 18:07 Сейчас в теме
(0)
Для информации.
Вот текст из описания CodeBase ("движка" 1C 7.7):
Appendix D: CodeBase Limits
Field Width
65517 bytes
254 for FoxPro or dBASE compatibility
32767 for Clipper compatibility
8. alex_bob 259 01.10.10 08:15 Сейчас в теме
(7) Спасибо за информацию. Хорошо бы еще понять, насколько объект XBase из восьмерки совместим с CodeBase. Кстати, если говорить о реквизитах объектов 1С77, то их длину не удастся сделать больше, чем 999 символов.
(5) BLOB здесь не при чём. Речь именно о строковых реквизитах ограниченной длины, но больше 254 символов.
9. hogik 447 01.10.10 16:41 Сейчас в теме
(8)
Ограничение на 999 не имеет отношение к CodeBase. Это ограничение самой 1С 7.7. Аналогичные ограничения могут быть и в 8.х. Надо писать тесты или искать в документациях.
А формально имеет смысл посмотреть заголовок DBF-а, пользуясь материалом из http://www.realcoding.net/article/view/222 , пропустив страницу с рекламой. ;-)
Для отправки сообщения требуется регистрация/авторизация