2 / 2 / 0
Регистрация: 25.08.2013
Сообщений: 38

В одном столбце таблицы БД заменить все пустые ячейки на содержимое ячеек в другом столбце из той же строки

23.01.2014, 17:21. Показов 4312. Ответов 14
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день.

Есть таблица .dbf и надо в одном столбце заменить все пустые ячейки на содержимое ячеек в другом столбце из той же строки.
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
23.01.2014, 17:21
Ответы с готовыми решениями:

Осуществить протягивание значений в одном столбце до строки последней заполненной ячейки в другом столбце
Доброго времени суток! Нужна помощь... Есть такая не тривиальная задача которую я даже не представляю как решить.. есть два...

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

Разбитие числа во все не пустые ячейки в столбце. Как сделать?
Здравствуйте задача состоит вот в чем, есть число и нужно его разбить на все не пустые ячейки в столбце над ним. Чтоб было более понятно...

14
 Аватар для Alex77755
11525 / 3812 / 683
Регистрация: 13.02.2009
Сообщений: 11,229
23.01.2014, 21:25
Подсказка с чего начать
Там вложение 875.zip
0
2 / 2 / 0
Регистрация: 25.08.2013
Сообщений: 38
24.01.2014, 12:30  [ТС]
Да Я бы и рад изучить всё это дело, да просто сейчас совсем некогда, а начальство требует редактировать таблицу...
Помогли бы формулой какой, был бы безмерно благодарен!
0
Супер-модератор
Эксперт функциональных языков программированияЭксперт Python
 Аватар для Catstail
38203 / 21135 / 4310
Регистрация: 12.02.2012
Сообщений: 34,741
Записей в блоге: 14
24.01.2014, 14:33
Загружаешь dbf в Excel, правишь, сохраняешь.
0
2 / 2 / 0
Регистрация: 25.08.2013
Сообщений: 38
24.01.2014, 15:08  [ТС]
Цитата Сообщение от Catstail Посмотреть сообщение
Загружаешь dbf в Excel, правишь, сохраняешь.
Нельзя, данные теряются. Там еще с кодировкой как то не так.
0
Супер-модератор
Эксперт функциональных языков программированияЭксперт Python
 Аватар для Catstail
38203 / 21135 / 4310
Регистрация: 12.02.2012
Сообщений: 34,741
Записей в блоге: 14
24.01.2014, 17:39
Выложи тестовый dbf-ник.
0
2 / 2 / 0
Регистрация: 25.08.2013
Сообщений: 38
28.01.2014, 12:27  [ТС]
Цитата Сообщение от Catstail Посмотреть сообщение
Выложи тестовый dbf-ник.
test.rar
Вот, так еще и не разобрался.

Задача:
1. Во всех пустых полях Nprik поставить - (тире)
2. В столбце Data_pr заменить все "не даты" датами из столбца Datn из той же строки.
1
2 / 2 / 0
Регистрация: 25.08.2013
Сообщений: 38
29.01.2014, 12:43  [ТС]
Цитата Сообщение от Catstail Посмотреть сообщение
Выложи тестовый dbf-ник.
Пользуясь DBFNavigator удалось изменить NPRIK такой командой:

PureBasic
1
IFF (nprik="",nprik="-",nprik=nprik)
Но почему то он не тире поставил, а нули...

А для столбца DATA_PR выдает ошибку (не соответствие типов оператора\операндов) при таком коде:

PureBasic
1
IFF (data_pr="",data_pr=datn,data_pr=data_pr)
Команды запускаются для выделенных ячеек.
0
Супер-модератор
Эксперт функциональных языков программированияЭксперт Python
 Аватар для Catstail
38203 / 21135 / 4310
Регистрация: 12.02.2012
Сообщений: 34,741
Записей в блоге: 14
29.01.2014, 14:03
Я сегодня вечером напишу код для Excel-а. Постараюсь.
0
2 / 2 / 0
Регистрация: 25.08.2013
Сообщений: 38
29.01.2014, 14:42  [ТС]
Цитата Сообщение от Catstail Посмотреть сообщение
Я сегодня вечером напишу код для Excel-а. Постараюсь.
Так в Excel-e не открыть, он открывает неведомые символы и записи (что 03, что 07, что 10)... Даже что то похожее на таблицу не открывает.
0
Супер-модератор
Эксперт функциональных языков программированияЭксперт Python
 Аватар для Catstail
38203 / 21135 / 4310
Регистрация: 12.02.2012
Сообщений: 34,741
Записей в блоге: 14
29.01.2014, 15:03
Сделаю, работать будет.
0
Супер-модератор
Эксперт функциональных языков программированияЭксперт Python
 Аватар для Catstail
38203 / 21135 / 4310
Регистрация: 12.02.2012
Сообщений: 34,741
Записей в блоге: 14
29.01.2014, 19:53
Лучший ответ Сообщение было отмечено The trick как решение

Решение

Сделал. Выкладываю законченное приложение в Excel

Кликните здесь для просмотра всего текста
Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
Sub Main()
Dim flg             As Boolean
Dim fldNam(1 To 20) As String
Dim fldOff(1 To 20) As String
Dim fldLen(1 To 20) As String
    dbf$ = Application.GetOpenFilename("Файлы dbf,*.dbf", , "Выбирайте файл")
    If UCase$(dbf$) = "FALSE" Or UCase$(dbf$) = "ЛОЖЬ" Then Exit Sub
    fi% = FreeFile
    Open dbf$ For Binary Access Read Write As #fi%
    Seek fi%, 5
    Get #fi%, , Nrec&
    Get #fi%, , OffBeg%
    Get #fi%, , Lrec%
    p& = 33
    n% = 0
    Do
       Seek #fi%, p&
       C11$ = Space$(11)
       Get #fi%, , C11$
       If Left$(C11$, 1) = Chr$(13) Then Exit Do
       n% = n% + 1
       k% = InStr(C11$, Chr$(0))
       If k% = 0 Then
          fldNam(n%) = C11$
       Else
          fldNam(n%) = Left(C11$, k% - 1)
       End If
       tmp$ = " "
       Get #fi%, , tmp$
       Get #fi%, , Off&
       Get #fi%, , ll%
       fldOff(n%) = Off& + 1
       fldLen(n%) = ll%
       p& = p& + 32
    Loop
    For i% = 1 To n%
        If UCase$(fldNam(i%)) = "NPRIK" Then
           Off_Nprik% = fldOff(i%)
           Len_Nprik% = fldLen(i%)
        ElseIf UCase$(fldNam(i%)) = "DATA_PR" Then
           Off_Datapr% = fldOff(i%)
           Len_Datapr% = fldLen(i%)
        ElseIf UCase$(fldNam(i%)) = "DATN" Then
           Off_Datn% = fldOff(i%)
           Len_Datn% = fldLen(i%)
        End If
    Next i%
    Seek #fi%, OffBeg% + 1
    For iii& = 1 To Nrec&
        Application.StatusBar = "Обработка записи " + CStr(iii&)
        Buf$ = Space$(Lrec%)
        Get #fi%, , Buf$
        flg = False
        If Mid$(Buf$, Off_Nprik%, Len_Nprik%) = Space$(Len_Nprik%) Then
           Mid$(Buf$, Off_Nprik%, 1) = "-"
           flg = True
        End If
        If Mid$(Buf$, Off_Datapr%, Len_Datapr%) = Space$(Len_Datapr%) Then
           Mid$(Buf$, Off_Datapr%, Len_Datapr%) = Mid$(Buf$, Off_Datn%, Len_Datn%)
           flg = True
        End If
        If flg Then
           ppp& = Loc(fi%)
           Seek fi%, ppp& - Lrec% + 1
           Put #fi%, , Buf$
        End If
    Next iii&
    Close #fi%
    Application.StatusBar = ""
    MsgBox "Готово!"
End Sub


Во вложении твой dbf-ник, обработанный программой. Открываешь книгу, щелкаешь по надписи "Пуск", выбираешь файл.
Вложения
Тип файла: zip Задачи-VBA-B3.zip (72.6 Кб, 6 просмотров)
1
2 / 2 / 0
Регистрация: 25.08.2013
Сообщений: 38
30.01.2014, 08:52  [ТС]
Цитата Сообщение от Catstail Посмотреть сообщение
Сделал. Выкладываю законченное приложение в Excel

Кликните здесь для просмотра всего текста
Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
Sub Main()
Dim flg             As Boolean
Dim fldNam(1 To 20) As String
Dim fldOff(1 To 20) As String
Dim fldLen(1 To 20) As String
    dbf$ = Application.GetOpenFilename("Файлы dbf,*.dbf", , "Выбирайте файл")
    If UCase$(dbf$) = "FALSE" Or UCase$(dbf$) = "ЛОЖЬ" Then Exit Sub
    fi% = FreeFile
    Open dbf$ For Binary Access Read Write As #fi%
    Seek fi%, 5
    Get #fi%, , Nrec&
    Get #fi%, , OffBeg%
    Get #fi%, , Lrec%
    p& = 33
    n% = 0
    Do
       Seek #fi%, p&
       C11$ = Space$(11)
       Get #fi%, , C11$
       If Left$(C11$, 1) = Chr$(13) Then Exit Do
       n% = n% + 1
       k% = InStr(C11$, Chr$(0))
       If k% = 0 Then
          fldNam(n%) = C11$
       Else
          fldNam(n%) = Left(C11$, k% - 1)
       End If
       tmp$ = " "
       Get #fi%, , tmp$
       Get #fi%, , Off&
       Get #fi%, , ll%
       fldOff(n%) = Off& + 1
       fldLen(n%) = ll%
       p& = p& + 32
    Loop
    For i% = 1 To n%
        If UCase$(fldNam(i%)) = "NPRIK" Then
           Off_Nprik% = fldOff(i%)
           Len_Nprik% = fldLen(i%)
        ElseIf UCase$(fldNam(i%)) = "DATA_PR" Then
           Off_Datapr% = fldOff(i%)
           Len_Datapr% = fldLen(i%)
        ElseIf UCase$(fldNam(i%)) = "DATN" Then
           Off_Datn% = fldOff(i%)
           Len_Datn% = fldLen(i%)
        End If
    Next i%
    Seek #fi%, OffBeg% + 1
    For iii& = 1 To Nrec&
        Application.StatusBar = "Обработка записи " + CStr(iii&)
        Buf$ = Space$(Lrec%)
        Get #fi%, , Buf$
        flg = False
        If Mid$(Buf$, Off_Nprik%, Len_Nprik%) = Space$(Len_Nprik%) Then
           Mid$(Buf$, Off_Nprik%, 1) = "-"
           flg = True
        End If
        If Mid$(Buf$, Off_Datapr%, Len_Datapr%) = Space$(Len_Datapr%) Then
           Mid$(Buf$, Off_Datapr%, Len_Datapr%) = Mid$(Buf$, Off_Datn%, Len_Datn%)
           flg = True
        End If
        If flg Then
           ppp& = Loc(fi%)
           Seek fi%, ppp& - Lrec% + 1
           Put #fi%, , Buf$
        End If
    Next iii&
    Close #fi%
    Application.StatusBar = ""
    MsgBox "Готово!"
End Sub


Во вложении твой dbf-ник, обработанный программой. Открываешь книгу, щелкаешь по надписи "Пуск", выбираешь файл.
Спасибо большое.
Серьезное такое решение) Я искал что то проще и нашел.

Все уложилось в две команды для FoxPro.
PureBasic
1
2
repl nprik with "-" for nprik="0"
repl data_pr with datn for nprik="-"
Еще раз спасибо за ответ, будет как пособие VB с базами данных.
0
Супер-модератор
Эксперт функциональных языков программированияЭксперт Python
 Аватар для Catstail
38203 / 21135 / 4310
Регистрация: 12.02.2012
Сообщений: 34,741
Записей в блоге: 14
30.01.2014, 11:05
Так у тебя FoxPro под руками? А чего было тогда грузить?...
0
2 / 2 / 0
Регистрация: 25.08.2013
Сообщений: 38
30.01.2014, 11:14  [ТС]
Цитата Сообщение от Catstail Посмотреть сообщение
Так у тебя FoxPro под руками? А чего было тогда грузить?...
Я до этого никогда не пользовался FoxPro, я даже не знал что он открывает .dbf, а до кучи я даже не предполагал что FoxPro это своего рода компилятор.
У нас он ставиться с программой для учета.

А покапавшись в инете по языку dBase нашел вот эту команду и то что в FoxPro юзать её лучше.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
30.01.2014, 11:14
Помогаю со студенческими работами здесь

Перенос значение ячейки в другую ячейку при появлении первой информации в соседнем столбце той же строки
Всех женщин с праздником 8-го марта! :kissing: Подскажите пожалуйста, как выводить значение ячейки в другую ячейку при условии...

В заданной матрице найти минимальный элемент и заменить на него все элементы в той же строке и столбце
Дана квадратная матрица А порядка n. Составить программу, которая находит минимальный элемент и все элементы, расположенные в одной строке...

Как выделить цветом значения в столбце, которые содержатся в другом столбце другого листа
Как выделить цветом значения в столбце , которые содержатся в другом столбце другого листа ?

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

Ячейки в одном столбце, но с разными масками
В продолжение темы(когда-то спрашивала про ячейки разной ширины в одном столбце, решили что все ячейки в столбцах будут одной ширины )...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
15
Ответ Создать тему
Опции темы

Новые блоги и статьи
Валидация и контроль данных табличной части документа перед записью
Maks 22.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в КА2. Задача: контроль и валидация данных табличной части документа перед записью с учетом регламента компании. . .
Отчёт о затраченных материалах за определенный период с макетом печатной формы
Maks 21.04.2026
Отчёт из решения ниже размещён в конфигурации КА2. Задача: разработка отчёта по затраченным материалам за определённый период, с возможностью вывода печатной формы отчёта с шапкой и подвалом. В. . .
Отчёт о спецтехнике находящейся в ремонте
Maks 20.04.2026
Отчёт из решения ниже размещен в конфигурации КА2. Задача: отобразить спецтехнику, которая на данный момент находится в ремонте. Есть нетиповой документ "Заявка на ремонт спецтехники" который. . .
Памятка для бота и "визитка" для читателей "Semantic Universe Layer (Слой семантической вселенной)"
Hrethgir 19.04.2026
Сгенерировано для краткого описания по случаю сборки и компиляции скелета серверного приложения. И пусть после этого скажут, что статьи сгенерированные AI - туфта и не интересно. И это не реклама -. . .
Запрет удаления строк ТЧ документа при определённом условии
Maks 19.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "Аккумуляторы", разработанного в конфигурации КА2. У данного документа есть ТЧ, в которой в зависимости от прав доступа. . .
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут Суть: - Группа наркоманов из 10 человек. - Только один инфицирован ВИЧ. - Колются одной иглой. - Колются раз в день. - Колются последовательно через. . .
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru